[INFO] cloning repository https://github.com/mlasala45/polyspheres-generator-library-rs
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/mlasala45/polyspheres-generator-library-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmlasala45%2Fpolyspheres-generator-library-rs", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmlasala45%2Fpolyspheres-generator-library-rs'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 647f4a80a74726c3895b88bc25374915ba5c5ceb
[INFO] checking mlasala45/polyspheres-generator-library-rs against master#8b6b15b877fbceb1ee5d9a5a4746e7515901574a for pr-147294
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmlasala45%2Fpolyspheres-generator-library-rs" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/mlasala45/polyspheres-generator-library-rs
[INFO] finished tweaking git repo https://github.com/mlasala45/polyspheres-generator-library-rs
[INFO] tweaked toml for git repo https://github.com/mlasala45/polyspheres-generator-library-rs written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mlasala45/polyspheres-generator-library-rs on toolchain 8b6b15b877fbceb1ee5d9a5a4746e7515901574a
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/mlasala45/polyspheres-generator-library-rs 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" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "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 2024 which implies `resolver = "3"`
[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 2024 resolver, specify `workspace.resolver = "3"` 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]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded whirlwind v0.1.1
[INFO] [stderr]   Downloaded wgpu-core-deps-emscripten v26.0.0
[INFO] [stderr]   Downloaded wgpu-core-deps-windows-linux-android v26.0.0
[INFO] [stderr]   Downloaded ordered-float v5.0.0
[INFO] [stderr]   Downloaded wgpu-core-deps-apple v26.0.0
[INFO] [stderr]   Downloaded rand_xoshiro v0.7.0
[INFO] [stderr]   Downloaded fast_poisson v1.0.2
[INFO] [stderr]   Downloaded cmov v0.3.1
[INFO] [stderr]   Downloaded sorted-vec v0.8.6
[INFO] [stderr]   Downloaded qhull v0.4.0
[INFO] [stderr]   Downloaded wgpu-types v26.0.0
[INFO] [stderr]   Downloaded delaunator v1.0.2
[INFO] [stderr]   Downloaded console-api v0.8.1
[INFO] [stderr]   Downloaded voronoice v0.2.0
[INFO] [stderr]   Downloaded console-subscriber v0.4.1
[INFO] [stderr]   Downloaded kiddo v5.2.2
[INFO] [stderr]   Downloaded aws-lc-rs v1.13.2
[INFO] [stderr]   Downloaded wgpu v26.0.1
[INFO] [stderr]   Downloaded qhull-sys v0.4.0
[INFO] [stderr]   Downloaded wgpu-core v26.0.1
[INFO] [stderr]   Downloaded wgpu-hal v26.0.0
[INFO] [stderr]   Downloaded naga v26.0.0
[INFO] [stderr]   Downloaded glam v0.30.4
[INFO] [stderr]   Downloaded metal v0.32.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 54570ce3a09ce5a2c8edfb32fd55ac13408cfb12e3f89359278f7878f6be56dc
[INFO] running `Command { std: "docker" "start" "-a" "54570ce3a09ce5a2c8edfb32fd55ac13408cfb12e3f89359278f7878f6be56dc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "54570ce3a09ce5a2c8edfb32fd55ac13408cfb12e3f89359278f7878f6be56dc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "54570ce3a09ce5a2c8edfb32fd55ac13408cfb12e3f89359278f7878f6be56dc", kill_on_drop: false }`
[INFO] [stdout] 54570ce3a09ce5a2c8edfb32fd55ac13408cfb12e3f89359278f7878f6be56dc
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+8b6b15b877fbceb1ee5d9a5a4746e7515901574a" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5e9cb98083e15bfd4596498af23448344fd16fdbf2223c243b115f94c6dc6547
[INFO] running `Command { std: "docker" "start" "-a" "5e9cb98083e15bfd4596498af23448344fd16fdbf2223c243b115f94c6dc6547", kill_on_drop: false }`
[INFO] [stderr] warning: virtual workspace defaulting to `resolver = "1"` despite one or more workspace members being on edition 2024 which implies `resolver = "3"`
[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 2024 resolver, specify `workspace.resolver = "3"` 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 proc-macro2 v1.0.95
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling shlex v1.3.0
[INFO] [stderr]    Compiling libm v0.2.15
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling rustversion v1.0.21
[INFO] [stderr]    Compiling cfg_aliases v0.2.1
[INFO] [stderr]    Compiling zerocopy v0.8.26
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling dunce v1.0.5
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]    Compiling glob v0.3.2
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]    Compiling jobserver v0.1.33
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]     Checking half v2.6.0
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling cc v1.2.29
[INFO] [stderr]    Compiling anyhow v1.0.98
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling prettyplease v0.2.35
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]    Compiling aws-lc-rs v1.13.2
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling cfg-if v1.0.1
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling clang-sys v1.8.1
[INFO] [stderr]    Compiling libloading v0.8.8
[INFO] [stderr]    Compiling cmake v0.1.54
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]     Checking ordered-float v5.0.0
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling naga v26.0.0
[INFO] [stderr]    Compiling khronos-egl v6.0.0
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]     Checking bit-vec v0.8.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling bindgen v0.69.5
[INFO] [stderr]    Compiling ash v0.38.0+1.3.281
[INFO] [stderr]    Compiling home v0.5.11
[INFO] [stderr]     Checking codespan-reporting v0.12.0
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]     Checking bit-set v0.8.0
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]     Checking rand_core v0.9.3
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling wgpu-hal v26.0.0
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling az v1.2.1
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]    Compiling aws-lc-sys v0.30.0
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling typenum v1.18.0
[INFO] [stderr]    Compiling generator v0.8.5
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]     Checking glow v0.16.0
[INFO] [stderr]     Checking profiling v1.0.17
[INFO] [stderr]    Compiling fixed v1.29.0
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]    Compiling rustls v0.23.29
[INFO] [stderr]    Compiling serde_json v1.0.141
[INFO] [stderr]    Compiling doc-comment v0.3.3
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]    Compiling fs-err v3.1.1
[INFO] [stderr]    Compiling wgpu-core v26.0.1
[INFO] [stderr]     Checking crc32fast v1.4.2
[INFO] [stderr]    Compiling litrs v0.4.1
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]     Checking flate2 v1.1.2
[INFO] [stderr]     Checking rand v0.9.1
[INFO] [stderr]    Compiling wgpu v26.0.1
[INFO] [stderr]     Checking array-init v2.1.0
[INFO] [stderr]     Checking cmov v0.3.1
[INFO] [stderr]    Compiling winapi v0.3.9
[INFO] [stderr]     Checking divrem v1.0.0
[INFO] [stderr]     Checking robust v0.2.3
[INFO] [stderr]     Checking sorted-vec v0.8.6
[INFO] [stderr]     Checking delaunator v1.0.2
[INFO] [stderr]     Checking hdrhistogram v7.5.4
[INFO] [stderr]     Checking rmp v0.8.14
[INFO] [stderr]     Checking rand_distr v0.5.1
[INFO] [stderr]     Checking crossbeam-channel v0.5.15
[INFO] [stderr]     Checking rustls-pemfile v2.2.0
[INFO] [stderr]     Checking rand_xoshiro v0.7.0
[INFO] [stderr]     Checking humantime v2.2.0
[INFO] [stderr]     Checking arc-swap v1.7.1
[INFO] [stderr]     Checking dashmap v6.1.0
[INFO] [stderr]     Checking voronoice v0.2.0
[INFO] [stderr]     Checking whirlwind v0.1.1
[INFO] [stderr]     Checking async-once-cell v0.5.4
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling bytemuck_derive v1.9.3
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling async-trait v0.1.88
[INFO] [stderr]     Checking tokio v1.46.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking bytemuck v1.23.1
[INFO] [stderr]    Compiling pin-project-internal v1.1.10
[INFO] [stderr]     Checking tokio-util v0.7.15
[INFO] [stderr]    Compiling prost-derive v0.13.5
[INFO] [stderr]    Compiling equator-macro v0.4.2
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking h2 v0.4.11
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]    Compiling async-stream-impl v0.3.6
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking hyper-util v0.1.15
[INFO] [stderr]     Checking equator v0.4.2
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]     Checking hyper-timeout v0.5.2
[INFO] [stderr]     Checking tokio-stream v0.1.17
[INFO] [stderr]     Checking aligned-vec v0.6.4
[INFO] [stderr]     Checking axum-core v0.5.2
[INFO] [stderr]     Checking async-stream v0.3.6
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]    Compiling axum-macros v0.5.0
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking pin-project v1.1.10
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking bitflags v2.9.1
[INFO] [stderr]     Checking prost v0.13.5
[INFO] [stderr]     Checking gpu-descriptor-types v0.2.0
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking gpu-descriptor v0.3.2
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking wgpu-types v26.0.0
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking prost-types v0.13.5
[INFO] [stderr]     Checking rustls-webpki v0.103.4
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_path_to_error v0.1.17
[INFO] [stderr]     Checking tower-http v0.6.6
[INFO] [stderr]     Checking rmp-serde v1.3.0
[INFO] [stderr]     Checking glam v0.30.4
[INFO] [stderr]    Compiling which v4.4.2
[INFO] [stderr]     Checking tonic v0.12.3
[INFO] [stderr]     Checking kiddo v5.2.2
[INFO] [stderr]     Checking tokio-rustls v0.26.2
[INFO] [stderr]     Checking fast_poisson v1.0.2
[INFO] [stderr]     Checking axum-server v0.7.2
[INFO] [stderr]     Checking console-api v0.8.1
[INFO] [stderr]     Checking axum v0.8.4
[INFO] [stderr]     Checking console-subscriber v0.4.1
[INFO] [stderr]     Checking wgpu-core-deps-windows-linux-android v26.0.0
[INFO] [stderr]    Compiling qhull-sys v0.4.0
[INFO] [stderr]     Checking qhull v0.4.0
[INFO] [stderr]     Checking polyspheres_generator v0.1.0 (/opt/rustwide/workdir/polyspheres_generator)
[INFO] [stdout] warning: unused import: `sync::Arc`
[INFO] [stdout]  --> polyspheres_generator/src/geodesic_voronoi.rs:7:31
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::{cmp::Ordering, fmt, sync::Arc};
[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: `futures::future::join_all`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:614:9
[INFO] [stdout]     |
[INFO] [stdout] 614 |     use futures::future::join_all;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hashbrown::HashMap`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:616:9
[INFO] [stdout]     |
[INFO] [stdout] 616 |     use hashbrown::HashMap;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> polyspheres_generator/src/geometry.rs:1:45
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{BinaryHeap, HashMap, HashSet};
[INFO] [stdout]   |                                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ReadMode` and `get_data_from_readback_buffer`
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:70:42
[INFO] [stdout]    |
[INFO] [stdout] 70 | ...   exit_and_close_span, gpu_utils::{get_data_from_readback_buffer, get_enqueued_readback_buffer, GpuContext, ReadMode}, thread_utils::...
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DEBUG_DATA`
[INFO] [stdout]   --> polyspheres_generator/src/polyspheres.rs:29:268
[INFO] [stdout]    |
[INFO] [stdout] 29 | ...olyMesh, projection_utils, relaxation::{self, RelaxSettings}, DEBUG_DATA
[INFO] [stdout]    |                                                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> polyspheres_generator/src/projection_utils.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `angles_sorted`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:280:34
[INFO] [stdout]     |
[INFO] [stdout] 280 |             let (indices_sorted, angles_sorted): (Vec<_>, Vec<_>) =
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_angles_sorted`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `readback_pred`
[INFO] [stdout]     --> polyspheres_generator/src/geodesic_voronoi.rs:1055:17
[INFO] [stdout]      |
[INFO] [stdout] 1055 |             let readback_pred = get_enqueued_readback_buffer(
[INFO] [stdout]      |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_readback_pred`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `readback_triad`
[INFO] [stdout]     --> polyspheres_generator/src/geodesic_voronoi.rs:1060:17
[INFO] [stdout]      |
[INFO] [stdout] 1060 |             let readback_triad =
[INFO] [stdout]      |                 ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_readback_triad`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sync::Arc`
[INFO] [stdout]  --> polyspheres_generator/src/geodesic_voronoi.rs:7:31
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::{cmp::Ordering, fmt, sync::Arc};
[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: `futures::future::join_all`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:614:9
[INFO] [stdout]     |
[INFO] [stdout] 614 |     use futures::future::join_all;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `hashbrown::HashMap`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:616:9
[INFO] [stdout]     |
[INFO] [stdout] 616 |     use hashbrown::HashMap;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> polyspheres_generator/src/geometry.rs:1:45
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{BinaryHeap, HashMap, HashSet};
[INFO] [stdout]   |                                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ReadMode` and `get_data_from_readback_buffer`
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:70:42
[INFO] [stdout]    |
[INFO] [stdout] 70 | ...   exit_and_close_span, gpu_utils::{get_data_from_readback_buffer, get_enqueued_readback_buffer, GpuContext, ReadMode}, thread_utils::...
[INFO] [stdout]    |                                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^                                            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DEBUG_DATA`
[INFO] [stdout]   --> polyspheres_generator/src/polyspheres.rs:29:268
[INFO] [stdout]    |
[INFO] [stdout] 29 | ...olyMesh, projection_utils, relaxation::{self, RelaxSettings}, DEBUG_DATA
[INFO] [stdout]    |                                                                  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> polyspheres_generator/src/projection_utils.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:387:74
[INFO] [stdout]     |
[INFO] [stdout] 387 |             let (callback, future) = get_awaitable_callback_with_result(|result| {
[INFO] [stdout]     |                                                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `readback_pred`
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:288:17
[INFO] [stdout]     |
[INFO] [stdout] 288 |             let readback_pred =
[INFO] [stdout]     |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_readback_pred`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `has_valid_after_cutoff`
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:410:17
[INFO] [stdout]     |
[INFO] [stdout] 410 |             let has_valid_after_cutoff = converted[cutoff..].iter().any(|v| is_valid(v));
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_has_valid_after_cutoff`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `last_await`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:173:21
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let mut last_await = Instant::now();
[INFO] [stdout]     |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_last_await`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `log_await_interval`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:174:21
[INFO] [stdout]     |
[INFO] [stdout] 174 |             let mut log_await_interval = || {
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_await_interval`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:173:17
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let mut last_await = Instant::now();
[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: variable does not need to be mutable
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:174:17
[INFO] [stdout]     |
[INFO] [stdout] 174 |             let mut log_await_interval = || {
[INFO] [stdout]     |                 ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inside_boundary_2d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:297:29
[INFO] [stdout]     |
[INFO] [stdout] 297 |                         let inside_boundary_2d = projection_utils::is_point_inside_boundary(
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inside_boundary_2d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inside_boundary_3d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:304:29
[INFO] [stdout]     |
[INFO] [stdout] 304 |                         let inside_boundary_3d =
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inside_boundary_3d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inside_radius_3d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:311:29
[INFO] [stdout]     |
[INFO] [stdout] 311 |                         let inside_radius_3d = site_3d.distance(center) <= self.settings.sites_filtering_radius;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inside_radius_3d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `boundary_2d_scaled`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:217:17
[INFO] [stdout]     |
[INFO] [stdout] 217 |             let boundary_2d_scaled: Vec<Vec2> = boundary_2d_unscaled
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_boundary_2d_scaled`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sites_2d_filtered`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:291:37
[INFO] [stdout]     |
[INFO] [stdout] 291 |             let (sites_3d_filtered, sites_2d_filtered): (Vec<_>, Vec<_>) =
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sites_2d_filtered`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `boundary_final_culling_from2d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:362:17
[INFO] [stdout]     |
[INFO] [stdout] 362 |             let boundary_final_culling_from2d: Vec<Vec3> = projection_utils::project_2d_to_sphere(
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_boundary_final_culling_from2d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `join_handle`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:133:9
[INFO] [stdout]     |
[INFO] [stdout] 133 |     let join_handle = spawn_gpu_polling_thread(
[INFO] [stdout]     |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_join_handle`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `angles_sorted`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:280:34
[INFO] [stdout]     |
[INFO] [stdout] 280 |             let (indices_sorted, angles_sorted): (Vec<_>, Vec<_>) =
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_angles_sorted`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `readback_pred`
[INFO] [stdout]     --> polyspheres_generator/src/geodesic_voronoi.rs:1055:17
[INFO] [stdout]      |
[INFO] [stdout] 1055 |             let readback_pred = get_enqueued_readback_buffer(
[INFO] [stdout]      |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_readback_pred`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `readback_triad`
[INFO] [stdout]     --> polyspheres_generator/src/geodesic_voronoi.rs:1060:17
[INFO] [stdout]      |
[INFO] [stdout] 1060 |             let readback_triad =
[INFO] [stdout]      |                 ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_readback_triad`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:387:74
[INFO] [stdout]     |
[INFO] [stdout] 387 |             let (callback, future) = get_awaitable_callback_with_result(|result| {
[INFO] [stdout]     |                                                                          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `readback_pred`
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:288:17
[INFO] [stdout]     |
[INFO] [stdout] 288 |             let readback_pred =
[INFO] [stdout]     |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_readback_pred`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `has_valid_after_cutoff`
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:410:17
[INFO] [stdout]     |
[INFO] [stdout] 410 |             let has_valid_after_cutoff = converted[cutoff..].iter().any(|v| is_valid(v));
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_has_valid_after_cutoff`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `last_await`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:173:21
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let mut last_await = Instant::now();
[INFO] [stdout]     |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_last_await`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `log_await_interval`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:174:21
[INFO] [stdout]     |
[INFO] [stdout] 174 |             let mut log_await_interval = || {
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_await_interval`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:173:17
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let mut last_await = Instant::now();
[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: variable does not need to be mutable
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:174:17
[INFO] [stdout]     |
[INFO] [stdout] 174 |             let mut log_await_interval = || {
[INFO] [stdout]     |                 ----^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inside_boundary_2d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:297:29
[INFO] [stdout]     |
[INFO] [stdout] 297 |                         let inside_boundary_2d = projection_utils::is_point_inside_boundary(
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inside_boundary_2d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inside_boundary_3d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:304:29
[INFO] [stdout]     |
[INFO] [stdout] 304 |                         let inside_boundary_3d =
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inside_boundary_3d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `inside_radius_3d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:311:29
[INFO] [stdout]     |
[INFO] [stdout] 311 |                         let inside_radius_3d = site_3d.distance(center) <= self.settings.sites_filtering_radius;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_inside_radius_3d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `boundary_2d_scaled`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:217:17
[INFO] [stdout]     |
[INFO] [stdout] 217 |             let boundary_2d_scaled: Vec<Vec2> = boundary_2d_unscaled
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_boundary_2d_scaled`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `sites_2d_filtered`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:291:37
[INFO] [stdout]     |
[INFO] [stdout] 291 |             let (sites_3d_filtered, sites_2d_filtered): (Vec<_>, Vec<_>) =
[INFO] [stdout]     |                                     ^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sites_2d_filtered`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `boundary_final_culling_from2d`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:362:17
[INFO] [stdout]     |
[INFO] [stdout] 362 |             let boundary_final_culling_from2d: Vec<Vec3> = projection_utils::project_2d_to_sphere(
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_boundary_final_culling_from2d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `join_handle`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:133:9
[INFO] [stdout]     |
[INFO] [stdout] 133 |     let join_handle = spawn_gpu_polling_thread(
[INFO] [stdout]     |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_join_handle`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:906:14
[INFO] [stdout]     |
[INFO] [stdout] 906 |         for (i, &v) in self.verts.iter().enumerate() {
[INFO] [stdout]     |              ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:908:17
[INFO] [stdout]     |
[INFO] [stdout] 908 |             let entry = vert_map.entry(key).or_insert_with(|| {
[INFO] [stdout]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chunk_index`
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1111:5
[INFO] [stdout]      |
[INFO] [stdout] 1111 |     chunk_index: u32,
[INFO] [stdout]      |     ^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1111 |     _chunk_index: u32,
[INFO] [stdout]      |     +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `WORKGROUP_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 1111 -     chunk_index: u32,
[INFO] [stdout] 1111 +     gpu_utils::GPUBufferCompactor::WORKGROUP_SIZE: u32,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `site_2d`
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1129:17
[INFO] [stdout]      |
[INFO] [stdout] 1129 |             let site_2d = Vec2::new(site.x as f32, site.y as f32);
[INFO] [stdout]      |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_site_2d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `radius`
[INFO] [stdout]   --> polyspheres_generator/src/projection_utils.rs:91:5
[INFO] [stdout]    |
[INFO] [stdout] 91 |     radius: f32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 91 |     _radius: f32,
[INFO] [stdout]    |     +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `SAMPLE_SPACING_TO_THRESHOLD_MULT_FINE`
[INFO] [stdout]    |
[INFO] [stdout] 91 -     radius: f32,
[INFO] [stdout] 91 +     geodesic_voronoi::calculate_geodesic_voronoi::{closure#0}::{closure#0}::SAMPLE_SPACING_TO_THRESHOLD_MULT_FINE: f32,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `attrs`
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:124:27
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn on_new_span(&self, attrs: &span::Attributes, id: &Id, ctx: Context<S>) {
[INFO] [stdout]     |                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_attrs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:147:24
[INFO] [stdout]     |
[INFO] [stdout] 147 |     fn on_enter(&self, id: &Id, _ctx: Context<S>) {
[INFO] [stdout]     |                        ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:151:23
[INFO] [stdout]     |
[INFO] [stdout] 151 |     fn on_exit(&self, id: &Id, _ctx: Context<S>) {
[INFO] [stdout]     |                       ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:162:21
[INFO] [stdout]     |
[INFO] [stdout] 162 |                 Err(e) => {
[INFO] [stdout]     |                     ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:190:17
[INFO] [stdout]     |
[INFO] [stdout] 190 |             Err(err) => {
[INFO] [stdout]     |                 ^^^ help: if this is intentional, prefix it with an underscore: `_err`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:486:30
[INFO] [stdout]     |
[INFO] [stdout] 486 |                     Some(Err(err)) => {
[INFO] [stdout]     |                              ^^^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 486 |                     Some(Err(_err)) => {
[INFO] [stdout]     |                              +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `_`
[INFO] [stdout]     |
[INFO] [stdout] 486 -                     Some(Err(err)) => {
[INFO] [stdout] 486 +                     Some(Err(tracing::_)) => {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `geodesic_voronoi::VoroTriadsCalculator::Buffers` is more private than the item `geodesic_voronoi::VoroTriadsCalculator::VoroTriadsCalculator::buffers`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:632:9
[INFO] [stdout]     |
[INFO] [stdout] 632 |         pub buffers: Option<Buffers>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `geodesic_voronoi::VoroTriadsCalculator::VoroTriadsCalculator::buffers` is reachable at visibility `pub(in crate::geodesic_voronoi)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `geodesic_voronoi::VoroTriadsCalculator::Buffers` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:661:5
[INFO] [stdout]     |
[INFO] [stdout] 661 |     struct Buffers {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `TIME_START_PROGRAM` is never used
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:47:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | static TIME_START_PROGRAM: Lazy<Instant> = Lazy::new(Instant::now);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `SUBSCRIBER` is never used
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:53:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | static SUBSCRIBER: OnceCell<Arc<TrackingSubscriberState>> = OnceCell::new();
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DEBUG_DATA` is never used
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:55:8
[INFO] [stdout]    |
[INFO] [stdout] 55 | static DEBUG_DATA: OnceCell<VoroDebugInfo::VoroDebugInfo> = OnceCell::new();
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:97:13
[INFO] [stdout]    |
[INFO] [stdout] 97 |     Adapter(wgpu::RequestAdapterError),
[INFO] [stdout]    |     ------- ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InitGpuError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 97 -     Adapter(wgpu::RequestAdapterError),
[INFO] [stdout] 97 +     Adapter(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:98:12
[INFO] [stdout]    |
[INFO] [stdout] 98 |     Device(wgpu::RequestDeviceError),
[INFO] [stdout]    |     ------ ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InitGpuError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 98 -     Device(wgpu::RequestDeviceError),
[INFO] [stdout] 98 +     Device(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DistanceToSite` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/geodesic_voronoi.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct DistanceToSite {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SphericalGridIter` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:305:8
[INFO] [stdout]     |
[INFO] [stdout] 305 | struct SphericalGridIter {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:349:12
[INFO] [stdout]     |
[INFO] [stdout] 348 | impl SphericalGridIter {
[INFO] [stdout]     | ---------------------- associated function in this implementation
[INFO] [stdout] 349 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `circumcenter` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:378:4
[INFO] [stdout]     |
[INFO] [stdout] 378 | fn circumcenter(a: Vec3, b: Vec3, c: Vec3) -> Vec3 {
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perp_bisector` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:395:4
[INFO] [stdout]     |
[INFO] [stdout] 395 | fn perp_bisector(a: Vec3, b: Vec3, sphere_center: Vec3) -> Vec3 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `geodesic_dist` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:422:8
[INFO] [stdout]     |
[INFO] [stdout] 422 | pub fn geodesic_dist(a: &Vec3, b: &Vec3, sphere_center: Vec3, sphere_radius: f32) -> f32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BinNeighborhoodIter` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:513:8
[INFO] [stdout]     |
[INFO] [stdout] 513 | struct BinNeighborhoodIter {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bin_neighborhood_iter` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:550:4
[INFO] [stdout]     |
[INFO] [stdout] 550 | fn bin_neighborhood_iter(center: (u16, u16), bin_settings: &BinSettings) -> BinNeighborhoodIter {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `r_max_world` and `spacing` are never read
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:634:9
[INFO] [stdout]     |
[INFO] [stdout] 631 |     pub struct VoroTriadsCalculator<'a> {
[INFO] [stdout]     |                -------------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 634 |         r_max_world: f32,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout] 635 |         spacing: f32,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `quantize` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:22:4
[INFO] [stdout]    |
[INFO] [stdout] 22 | fn quantize(p: Vec3, grid_size: f32) -> (i32, i32, i32) {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `neighbor_bins` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:30:4
[INFO] [stdout]    |
[INFO] [stdout] 30 | fn neighbor_bins(bin: (i32, i32, i32)) -> Vec<(i32, i32, i32)> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_close_points` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:42:8
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub fn remove_close_points<I>(points: I, threshold: f32) -> Vec<Vec3>
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `avg_k_nearest_dist` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn avg_k_nearest_dist(points: Vec<Vec3>, k: u8) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `FromEnd` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:461:5
[INFO] [stdout]     |
[INFO] [stdout] 459 | pub enum ReadMode {
[INFO] [stdout]     |          -------- variant in this enum
[INFO] [stdout] 460 |     FromStart,
[INFO] [stdout] 461 |     FromEnd,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `bind_group_layout` and `dbg_id` are never read
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub struct GpuBufferCompactor<'a> {
[INFO] [stdout]    |                ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 81 |         pub bind_group_layout: &'a BindGroupLayout,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 82 |         pub dbg_id: u32,
[INFO] [stdout]    |             ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `readback_buffer` is never read
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:88:13
[INFO] [stdout]    |
[INFO] [stdout] 85 |     struct Buffers {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 88 |         pub readback_buffer: Buffer,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash_vec3_to_letter` is never used
[INFO] [stdout]  --> polyspheres_generator/src/misc_util.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn hash_vec3_to_letter(v: impl std::borrow::Borrow<Vec3>) -> char {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash_vec3_iter_to_string` is never used
[INFO] [stdout]   --> polyspheres_generator/src/misc_util.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub fn hash_vec3_iter_to_string<I>(iter: I) -> String
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ConvertsToPoint` is never used
[INFO] [stdout]  --> polyspheres_generator/src/polyspheres.rs:7:7
[INFO] [stdout]   |
[INFO] [stdout] 7 | trait ConvertsToPoint {
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `append_points` is never used
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1086:8
[INFO] [stdout]      |
[INFO] [stdout]  899 | impl PolyMesh {
[INFO] [stdout]      | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1086 |     fn append_points(mut self, points: Vec<Vec3>) -> Self {
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gen_voronoi` is never used
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1092:4
[INFO] [stdout]      |
[INFO] [stdout] 1092 | fn gen_voronoi(sites: &Vec<Vec2>, bounds_size: f32) -> Voronoi {
[INFO] [stdout]      |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `voro_to_polymesh` is never used
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1106:4
[INFO] [stdout]      |
[INFO] [stdout] 1106 | fn voro_to_polymesh(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `NoCulling` is never constructed
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1157:5
[INFO] [stdout]      |
[INFO] [stdout] 1154 | enum CullMode {
[INFO] [stdout]      |      -------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 1157 |     NoCulling,
[INFO] [stdout]      |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChunkContext` is never constructed
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1203:12
[INFO] [stdout]      |
[INFO] [stdout] 1203 | pub struct ChunkContext {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `determine_neighbors` is never used
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:879:12
[INFO] [stdout]     |
[INFO] [stdout] 879 |     pub fn determine_neighbors(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Boundary2` is never used
[INFO] [stdout]  --> polyspheres_generator/src/projection_utils.rs:4:6
[INFO] [stdout]   |
[INFO] [stdout] 4 | type Boundary2 = Vec<Vec2>;
[INFO] [stdout]   |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `spherify` is never used
[INFO] [stdout]   --> polyspheres_generator/src/projection_utils.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub fn spherify(point: Vec3, sphere_center: Vec3, radius: f32) -> Vec3 {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrackingSubscriberState` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct TrackingSubscriberState {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_active_spans` and `get_span_hierarchy` are never used
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl TrackingSubscriberState {
[INFO] [stdout]    | ---------------------------- methods in this implementation
[INFO] [stdout] 15 |     pub fn get_active_spans(&self) -> Vec<SpanInfo> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn get_span_hierarchy(&self, blacklist: &[&str]) -> Vec<SpanNode> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrackingSubscriber` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:85:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub struct TrackingSubscriber {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:90:12
[INFO] [stdout]    |
[INFO] [stdout] 89 | impl TrackingSubscriber {
[INFO] [stdout]    | ----------------------- associated function in this implementation
[INFO] [stdout] 90 |     pub fn new(state: Arc<TrackingSubscriberState>) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SpanInfo` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct SpanInfo {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SpanNode` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub struct SpanNode {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `VoroDebugInfo` should have a snake case name
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:445:9
[INFO] [stdout]     |
[INFO] [stdout] 445 | pub mod VoroDebugInfo {
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `voro_debug_info`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `VoroTriadsCalculator` should have a snake case name
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:612:5
[INFO] [stdout]     |
[INFO] [stdout] 612 | mod VoroTriadsCalculator {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `voro_triads_calculator`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `GPUBufferCompactor` should have a snake case name
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:64:9
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub mod GPUBufferCompactor {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `gpubuffer_compactor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `N` should have a snake case name
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:76:13
[INFO] [stdout]    |
[INFO] [stdout] 76 |         pub N: u64,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `PolySphereChunkGenerator` should have a snake case name
[INFO] [stdout]   --> polyspheres_generator/src/polyspheres.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub mod PolySphereChunkGenerator {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `poly_sphere_chunk_generator`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:906:14
[INFO] [stdout]     |
[INFO] [stdout] 906 |         for (i, &v) in self.verts.iter().enumerate() {
[INFO] [stdout]     |              ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `entry`
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:908:17
[INFO] [stdout]     |
[INFO] [stdout] 908 |             let entry = vert_map.entry(key).or_insert_with(|| {
[INFO] [stdout]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_entry`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `chunk_index`
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1111:5
[INFO] [stdout]      |
[INFO] [stdout] 1111 |     chunk_index: u32,
[INFO] [stdout]      |     ^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1111 |     _chunk_index: u32,
[INFO] [stdout]      |     +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `WORKGROUP_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 1111 -     chunk_index: u32,
[INFO] [stdout] 1111 +     gpu_utils::GPUBufferCompactor::WORKGROUP_SIZE: u32,
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `site_2d`
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1129:17
[INFO] [stdout]      |
[INFO] [stdout] 1129 |             let site_2d = Vec2::new(site.x as f32, site.y as f32);
[INFO] [stdout]      |                 ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_site_2d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `radius`
[INFO] [stdout]   --> polyspheres_generator/src/projection_utils.rs:91:5
[INFO] [stdout]    |
[INFO] [stdout] 91 |     radius: f32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]    |
[INFO] [stdout] 91 |     _radius: f32,
[INFO] [stdout]    |     +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `SAMPLE_SPACING_TO_THRESHOLD_MULT_FINE`
[INFO] [stdout]    |
[INFO] [stdout] 91 -     radius: f32,
[INFO] [stdout] 91 +     geodesic_voronoi::calculate_geodesic_voronoi::{closure#0}::{closure#0}::SAMPLE_SPACING_TO_THRESHOLD_MULT_FINE: f32,
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `attrs`
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:124:27
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn on_new_span(&self, attrs: &span::Attributes, id: &Id, ctx: Context<S>) {
[INFO] [stdout]     |                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_attrs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:147:24
[INFO] [stdout]     |
[INFO] [stdout] 147 |     fn on_enter(&self, id: &Id, _ctx: Context<S>) {
[INFO] [stdout]     |                        ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `id`
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:151:23
[INFO] [stdout]     |
[INFO] [stdout] 151 |     fn on_exit(&self, id: &Id, _ctx: Context<S>) {
[INFO] [stdout]     |                       ^^ help: if this is intentional, prefix it with an underscore: `_id`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `e`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:162:21
[INFO] [stdout]     |
[INFO] [stdout] 162 |                 Err(e) => {
[INFO] [stdout]     |                     ^ help: if this is intentional, prefix it with an underscore: `_e`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:190:17
[INFO] [stdout]     |
[INFO] [stdout] 190 |             Err(err) => {
[INFO] [stdout]     |                 ^^^ help: if this is intentional, prefix it with an underscore: `_err`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `err`
[INFO] [stdout]    --> polyspheres_generator/src/lib.rs:486:30
[INFO] [stdout]     |
[INFO] [stdout] 486 |                     Some(Err(err)) => {
[INFO] [stdout]     |                              ^^^
[INFO] [stdout]     |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 486 |                     Some(Err(_err)) => {
[INFO] [stdout]     |                              +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `_`
[INFO] [stdout]     |
[INFO] [stdout] 486 -                     Some(Err(err)) => {
[INFO] [stdout] 486 +                     Some(Err(tracing::_)) => {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `geodesic_voronoi::VoroTriadsCalculator::Buffers` is more private than the item `geodesic_voronoi::VoroTriadsCalculator::VoroTriadsCalculator::buffers`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:632:9
[INFO] [stdout]     |
[INFO] [stdout] 632 |         pub buffers: Option<Buffers>,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `geodesic_voronoi::VoroTriadsCalculator::VoroTriadsCalculator::buffers` is reachable at visibility `pub(in crate::geodesic_voronoi)`
[INFO] [stdout]     |
[INFO] [stdout] note: but type `geodesic_voronoi::VoroTriadsCalculator::Buffers` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:661:5
[INFO] [stdout]     |
[INFO] [stdout] 661 |     struct Buffers {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `TIME_START_PROGRAM` is never used
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:47:8
[INFO] [stdout]    |
[INFO] [stdout] 47 | static TIME_START_PROGRAM: Lazy<Instant> = Lazy::new(Instant::now);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `SUBSCRIBER` is never used
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:53:8
[INFO] [stdout]    |
[INFO] [stdout] 53 | static SUBSCRIBER: OnceCell<Arc<TrackingSubscriberState>> = OnceCell::new();
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DEBUG_DATA` is never used
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:55:8
[INFO] [stdout]    |
[INFO] [stdout] 55 | static DEBUG_DATA: OnceCell<VoroDebugInfo::VoroDebugInfo> = OnceCell::new();
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:97:13
[INFO] [stdout]    |
[INFO] [stdout] 97 |     Adapter(wgpu::RequestAdapterError),
[INFO] [stdout]    |     ------- ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InitGpuError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 97 -     Adapter(wgpu::RequestAdapterError),
[INFO] [stdout] 97 +     Adapter(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> polyspheres_generator/src/lib.rs:98:12
[INFO] [stdout]    |
[INFO] [stdout] 98 |     Device(wgpu::RequestDeviceError),
[INFO] [stdout]    |     ------ ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `InitGpuError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 98 -     Device(wgpu::RequestDeviceError),
[INFO] [stdout] 98 +     Device(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DistanceToSite` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/geodesic_voronoi.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct DistanceToSite {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SphericalGridIter` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:305:8
[INFO] [stdout]     |
[INFO] [stdout] 305 | struct SphericalGridIter {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:349:12
[INFO] [stdout]     |
[INFO] [stdout] 348 | impl SphericalGridIter {
[INFO] [stdout]     | ---------------------- associated function in this implementation
[INFO] [stdout] 349 |     pub fn new(
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `circumcenter` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:378:4
[INFO] [stdout]     |
[INFO] [stdout] 378 | fn circumcenter(a: Vec3, b: Vec3, c: Vec3) -> Vec3 {
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perp_bisector` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:395:4
[INFO] [stdout]     |
[INFO] [stdout] 395 | fn perp_bisector(a: Vec3, b: Vec3, sphere_center: Vec3) -> Vec3 {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `geodesic_dist` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:422:8
[INFO] [stdout]     |
[INFO] [stdout] 422 | pub fn geodesic_dist(a: &Vec3, b: &Vec3, sphere_center: Vec3, sphere_radius: f32) -> f32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BinNeighborhoodIter` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:513:8
[INFO] [stdout]     |
[INFO] [stdout] 513 | struct BinNeighborhoodIter {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bin_neighborhood_iter` is never used
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:550:4
[INFO] [stdout]     |
[INFO] [stdout] 550 | fn bin_neighborhood_iter(center: (u16, u16), bin_settings: &BinSettings) -> BinNeighborhoodIter {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `r_max_world` and `spacing` are never read
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:634:9
[INFO] [stdout]     |
[INFO] [stdout] 631 |     pub struct VoroTriadsCalculator<'a> {
[INFO] [stdout]     |                -------------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 634 |         r_max_world: f32,
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout] 635 |         spacing: f32,
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `quantize` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:22:4
[INFO] [stdout]    |
[INFO] [stdout] 22 | fn quantize(p: Vec3, grid_size: f32) -> (i32, i32, i32) {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `neighbor_bins` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:30:4
[INFO] [stdout]    |
[INFO] [stdout] 30 | fn neighbor_bins(bin: (i32, i32, i32)) -> Vec<(i32, i32, i32)> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_close_points` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:42:8
[INFO] [stdout]    |
[INFO] [stdout] 42 | pub fn remove_close_points<I>(points: I, threshold: f32) -> Vec<Vec3>
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `avg_k_nearest_dist` is never used
[INFO] [stdout]   --> polyspheres_generator/src/geometry.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn avg_k_nearest_dist(points: Vec<Vec3>, k: u8) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `FromEnd` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/gpu_utils.rs:461:5
[INFO] [stdout]     |
[INFO] [stdout] 459 | pub enum ReadMode {
[INFO] [stdout]     |          -------- variant in this enum
[INFO] [stdout] 460 |     FromStart,
[INFO] [stdout] 461 |     FromEnd,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `bind_group_layout` and `dbg_id` are never read
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:81:13
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub struct GpuBufferCompactor<'a> {
[INFO] [stdout]    |                ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 81 |         pub bind_group_layout: &'a BindGroupLayout,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 82 |         pub dbg_id: u32,
[INFO] [stdout]    |             ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `readback_buffer` is never read
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:88:13
[INFO] [stdout]    |
[INFO] [stdout] 85 |     struct Buffers {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 88 |         pub readback_buffer: Buffer,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash_vec3_to_letter` is never used
[INFO] [stdout]  --> polyspheres_generator/src/misc_util.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn hash_vec3_to_letter(v: impl std::borrow::Borrow<Vec3>) -> char {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hash_vec3_iter_to_string` is never used
[INFO] [stdout]   --> polyspheres_generator/src/misc_util.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub fn hash_vec3_iter_to_string<I>(iter: I) -> String
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `ConvertsToPoint` is never used
[INFO] [stdout]  --> polyspheres_generator/src/polyspheres.rs:7:7
[INFO] [stdout]   |
[INFO] [stdout] 7 | trait ConvertsToPoint {
[INFO] [stdout]   |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `append_points` is never used
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1086:8
[INFO] [stdout]      |
[INFO] [stdout]  899 | impl PolyMesh {
[INFO] [stdout]      | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1086 |     fn append_points(mut self, points: Vec<Vec3>) -> Self {
[INFO] [stdout]      |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gen_voronoi` is never used
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1092:4
[INFO] [stdout]      |
[INFO] [stdout] 1092 | fn gen_voronoi(sites: &Vec<Vec2>, bounds_size: f32) -> Voronoi {
[INFO] [stdout]      |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `voro_to_polymesh` is never used
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1106:4
[INFO] [stdout]      |
[INFO] [stdout] 1106 | fn voro_to_polymesh(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `NoCulling` is never constructed
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1157:5
[INFO] [stdout]      |
[INFO] [stdout] 1154 | enum CullMode {
[INFO] [stdout]      |      -------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 1157 |     NoCulling,
[INFO] [stdout]      |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ChunkContext` is never constructed
[INFO] [stdout]     --> polyspheres_generator/src/polyspheres.rs:1203:12
[INFO] [stdout]      |
[INFO] [stdout] 1203 | pub struct ChunkContext {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `determine_neighbors` is never used
[INFO] [stdout]    --> polyspheres_generator/src/polyspheres.rs:879:12
[INFO] [stdout]     |
[INFO] [stdout] 879 |     pub fn determine_neighbors(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Boundary2` is never used
[INFO] [stdout]  --> polyspheres_generator/src/projection_utils.rs:4:6
[INFO] [stdout]   |
[INFO] [stdout] 4 | type Boundary2 = Vec<Vec2>;
[INFO] [stdout]   |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `spherify` is never used
[INFO] [stdout]   --> polyspheres_generator/src/projection_utils.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 81 | pub fn spherify(point: Vec3, sphere_center: Vec3, radius: f32) -> Vec3 {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrackingSubscriberState` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct TrackingSubscriberState {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_active_spans` and `get_span_hierarchy` are never used
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl TrackingSubscriberState {
[INFO] [stdout]    | ---------------------------- methods in this implementation
[INFO] [stdout] 15 |     pub fn get_active_spans(&self) -> Vec<SpanInfo> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn get_span_hierarchy(&self, blacklist: &[&str]) -> Vec<SpanNode> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TrackingSubscriber` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:85:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | pub struct TrackingSubscriber {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:90:12
[INFO] [stdout]    |
[INFO] [stdout] 89 | impl TrackingSubscriber {
[INFO] [stdout]    | ----------------------- associated function in this implementation
[INFO] [stdout] 90 |     pub fn new(state: Arc<TrackingSubscriberState>) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SpanInfo` is never constructed
[INFO] [stdout]   --> polyspheres_generator/src/tracing.rs:96:12
[INFO] [stdout]    |
[INFO] [stdout] 96 | pub struct SpanInfo {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SpanNode` is never constructed
[INFO] [stdout]    --> polyspheres_generator/src/tracing.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub struct SpanNode {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `VoroDebugInfo` should have a snake case name
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:445:9
[INFO] [stdout]     |
[INFO] [stdout] 445 | pub mod VoroDebugInfo {
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: convert the identifier to snake case: `voro_debug_info`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `VoroTriadsCalculator` should have a snake case name
[INFO] [stdout]    --> polyspheres_generator/src/geodesic_voronoi.rs:612:5
[INFO] [stdout]     |
[INFO] [stdout] 612 | mod VoroTriadsCalculator {
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `voro_triads_calculator`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `GPUBufferCompactor` should have a snake case name
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:64:9
[INFO] [stdout]    |
[INFO] [stdout] 64 | pub mod GPUBufferCompactor {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `gpubuffer_compactor`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `N` should have a snake case name
[INFO] [stdout]   --> polyspheres_generator/src/gpu_utils.rs:76:13
[INFO] [stdout]    |
[INFO] [stdout] 76 |         pub N: u64,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `PolySphereChunkGenerator` should have a snake case name
[INFO] [stdout]   --> polyspheres_generator/src/polyspheres.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub mod PolySphereChunkGenerator {
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `poly_sphere_chunk_generator`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 8m 58s
[INFO] running `Command { std: "docker" "inspect" "5e9cb98083e15bfd4596498af23448344fd16fdbf2223c243b115f94c6dc6547", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5e9cb98083e15bfd4596498af23448344fd16fdbf2223c243b115f94c6dc6547", kill_on_drop: false }`
[INFO] [stdout] 5e9cb98083e15bfd4596498af23448344fd16fdbf2223c243b115f94c6dc6547
