[INFO] cloning repository https://github.com/blue-codes-yep/Acoustic-Simulation
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/blue-codes-yep/Acoustic-Simulation" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fblue-codes-yep%2FAcoustic-Simulation", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fblue-codes-yep%2FAcoustic-Simulation'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] bc7cebe8867afbc9fd66e5a6e0bcae27c0ecdbb4
[INFO] checking blue-codes-yep/Acoustic-Simulation against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fblue-codes-yep%2FAcoustic-Simulation" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/blue-codes-yep/Acoustic-Simulation
[INFO] finished tweaking git repo https://github.com/blue-codes-yep/Acoustic-Simulation
[INFO] tweaked toml for git repo https://github.com/blue-codes-yep/Acoustic-Simulation written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/blue-codes-yep/Acoustic-Simulation on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/blue-codes-yep/Acoustic-Simulation already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded simba v0.8.1
[INFO] [stderr]   Downloaded bytemuck v1.14.0
[INFO] [stderr]   Downloaded num_enum_derive v0.5.11
[INFO] [stderr]   Downloaded crossbeam v0.8.2
[INFO] [stderr]   Downloaded nalgebra-macros v0.2.1
[INFO] [stderr]   Downloaded which v3.1.1
[INFO] [stderr]   Downloaded thiserror-impl v1.0.50
[INFO] [stderr]   Downloaded crossbeam-queue v0.3.9
[INFO] [stderr]   Downloaded rawpointer v0.2.1
[INFO] [stderr]   Downloaded allocator-api2 v0.2.16
[INFO] [stderr]   Downloaded shlex v1.2.0
[INFO] [stderr]   Downloaded coreaudio-sys v0.2.14
[INFO] [stderr]   Downloaded mach2 v0.4.1
[INFO] [stderr]   Downloaded crossbeam-deque v0.8.4
[INFO] [stderr]   Downloaded thiserror v1.0.50
[INFO] [stderr]   Downloaded pkg-config v0.3.27
[INFO] [stderr]   Downloaded termcolor v1.4.0
[INFO] [stderr]   Downloaded asio-sys v0.2.1
[INFO] [stderr]   Downloaded clang-sys v1.6.1
[INFO] [stderr]   Downloaded env_logger v0.8.4
[INFO] [stderr]   Downloaded matrixmultiply v0.3.8
[INFO] [stderr]   Downloaded safe_arch v0.7.1
[INFO] [stderr]   Downloaded jni v0.19.0
[INFO] [stderr]   Downloaded alsa v0.7.1
[INFO] [stderr]   Downloaded cpal v0.15.2
[INFO] [stderr]   Downloaded combine v4.6.6
[INFO] [stderr]   Downloaded oboe-sys v0.5.0
[INFO] [stderr]   Downloaded nom v5.1.3
[INFO] [stderr]   Downloaded winnow v0.5.28
[INFO] [stderr]   Downloaded bindgen v0.56.0
[INFO] [stderr]   Downloaded rapier3d v0.17.2
[INFO] [stderr]   Downloaded bindgen v0.69.1
[INFO] [stderr]   Downloaded syn v2.0.41
[INFO] [stderr]   Downloaded parry3d v0.13.5
[INFO] [stderr]   Downloaded spade v2.4.1
[INFO] [stderr]   Downloaded zerocopy v0.7.31
[INFO] [stderr]   Downloaded crossbeam-channel v0.5.9
[INFO] [stderr]   Downloaded jni v0.20.0
[INFO] [stderr]   Downloaded ahash v0.8.6
[INFO] [stderr]   Downloaded wide v0.7.13
[INFO] [stderr]   Downloaded nalgebra v0.32.3
[INFO] [stderr]   Downloaded jobserver v0.1.27
[INFO] [stderr]   Downloaded crossbeam-epoch v0.9.16
[INFO] [stderr]   Downloaded crossbeam-utils v0.8.17
[INFO] [stderr]   Downloaded zerocopy-derive v0.7.31
[INFO] [stderr]   Downloaded robust v1.1.0
[INFO] [stderr]   Downloaded walkdir v2.4.0
[INFO] [stderr]   Downloaded num_enum v0.5.11
[INFO] [stderr]   Downloaded num-derive v0.3.3
[INFO] [stderr]   Downloaded oboe v0.5.0
[INFO] [stderr]   Downloaded windows v0.46.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c2a30a05f68c31d91f234e09659227c12a7f075fa8961c6eb8d7c70abdaf5021
[INFO] running `Command { std: "docker" "start" "-a" "c2a30a05f68c31d91f234e09659227c12a7f075fa8961c6eb8d7c70abdaf5021", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c2a30a05f68c31d91f234e09659227c12a7f075fa8961c6eb8d7c70abdaf5021", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c2a30a05f68c31d91f234e09659227c12a7f075fa8961c6eb8d7c70abdaf5021", kill_on_drop: false }`
[INFO] [stdout] c2a30a05f68c31d91f234e09659227c12a7f075fa8961c6eb8d7c70abdaf5021
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c7b2bcb5015dc63c41ee59df2be2eae9088bd0bf3e969e6cc691d7a31d4621ff
[INFO] running `Command { std: "docker" "start" "-a" "c7b2bcb5015dc63c41ee59df2be2eae9088bd0bf3e969e6cc691d7a31d4621ff", kill_on_drop: false }`
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling proc-macro2 v1.0.70
[INFO] [stderr]    Compiling libc v0.2.151
[INFO] [stderr]    Compiling crossbeam-utils v0.8.17
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling memoffset v0.9.0
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking bytemuck v1.14.0
[INFO] [stderr]    Compiling paste v1.0.14
[INFO] [stderr]     Checking smallvec v1.11.2
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]    Compiling ahash v0.8.6
[INFO] [stderr]     Checking zerocopy v0.7.31
[INFO] [stderr]     Checking once_cell v1.19.0
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]    Compiling lock_api v0.4.11
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]     Checking rawpointer v0.2.1
[INFO] [stderr]     Checking allocator-api2 v0.2.16
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]     Checking robust v1.1.0
[INFO] [stderr]     Checking either v1.9.0
[INFO] [stderr]     Checking downcast-rs v1.2.0
[INFO] [stderr]     Checking arrayvec v0.7.4
[INFO] [stderr]     Checking wide v0.7.13
[INFO] [stderr]    Compiling cpal v0.15.2
[INFO] [stderr]     Checking rustc-hash v1.1.0
[INFO] [stderr]     Checking dasp_sample v0.11.0
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]     Checking vec_map v0.8.2
[INFO] [stderr]     Checking hashbrown v0.14.3
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]     Checking crossbeam-epoch v0.9.16
[INFO] [stderr]     Checking crossbeam-channel v0.5.9
[INFO] [stderr]     Checking crossbeam-queue v0.3.9
[INFO] [stderr]     Checking num-complex v0.4.4
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking spade v2.4.1
[INFO] [stderr]     Checking crossbeam-deque v0.8.4
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking alsa v0.7.1
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking crossbeam v0.8.2
[INFO] [stderr]     Checking simba v0.8.1
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]    Compiling num-derive v0.3.3
[INFO] [stderr]     Checking nalgebra v0.32.3
[INFO] [stderr]     Checking parry3d v0.13.5
[INFO] [stderr]     Checking rapier3d v0.17.2
[INFO] [stderr]     Checking acoustic_simulation v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Material` and `SoundWave`
[INFO] [stdout]  --> src/main.rs:4:22
[INFO] [stdout]   |
[INFO] [stdout] 4 | use models::models::{SoundWave, Material};
[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: `ImpulseJoint`
[INFO] [stdout]  --> src/engine/engine.rs:3:16
[INFO] [stdout]   |
[INFO] [stdout] 3 |     CCDSolver, ImpulseJoint, IntegrationParameters, MultibodyJointSet, RigidBodySet,
[INFO] [stdout]   |                ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::thread;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `body`
[INFO] [stdout]    --> src/engine/engine.rs:139:27
[INFO] [stdout]     |
[INFO] [stdout] 139 |         for (body_handle, body) in self.bodies.iter() {
[INFO] [stdout]     |                           ^^^^ help: if this is intentional, prefix it with an underscore: `_body`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `interacted_wave`
[INFO] [stdout]    --> src/engine/engine.rs:141:21
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 let interacted_wave = interact(wave, &material);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_interacted_wave`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `position`
[INFO] [stdout]  --> src/sound/sound.rs:8:69
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn generate_wave(sample_rate: f32, frequency: f32, volume: f32, position: Vector<f32>) -> Vec<f32> {
[INFO] [stdout]   |                                                                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_position`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `amplitude`
[INFO] [stdout]   --> src/sound/sound.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let amplitude: f32 = volume;  // Example calculation for amplitude
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_amplitude`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]   --> src/sound/sound.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 |     let direction = Vector::new(1.0, 0.0, 0.0);  // Example default direction
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `position`
[INFO] [stdout]   --> src/sound/sound.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let position: rapier3d::prelude::nalgebra::Matrix<f64, rapier3d::prelude::nalgebra::Const<3>, rapier3d::prelude::nalgebra::Const...
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_position`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut wave: Vec<f32> = generate_wave(44100.0, 528.0, 0.5, Vector::new(0.0, 0.0, 0.0));
[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: `sample_rate`
[INFO] [stdout]   --> src/main.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let sample_rate = 44100.0;
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sample_rate`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `frequency`
[INFO] [stdout]   --> src/main.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 |     let frequency = 528.0;
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_frequency`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `interact` is never used
[INFO] [stdout]   --> src/engine/engine.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn interact(wave: &SoundWave, material: &Material) -> SoundWave {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `absorption_coefficient` is never used
[INFO] [stdout]   --> src/engine/engine.rs:13:12
[INFO] [stdout]    |
[INFO] [stdout] 12 |     impl Material {
[INFO] [stdout]    |     ------------- method in this implementation
[INFO] [stdout] 13 |         fn absorption_coefficient(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `interact_mapping`, `step`, `process_sound_wave_interactions`, and `get_material_of_body` are never used
[INFO] [stdout]    --> src/engine/engine.rs:39:12
[INFO] [stdout]     |
[INFO] [stdout]  38 | impl Engine {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout]  39 |     pub fn interact_mapping(&self, wave: &SoundWave, material: &Material) -> SoundWave {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  87 |     pub fn step(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 138 |     pub fn process_sound_wave_interactions(&mut self, wave: &SoundWave) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |    pub fn get_material_of_body(&self, body_handle: RigidBodyHandle) -> Option<Material> {
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `frequency`, `amplitude`, `direction`, and `position` are never read
[INFO] [stdout]  --> src/models/models.rs:6:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct SoundWave {
[INFO] [stdout]   |            --------- fields in this struct
[INFO] [stdout] 6 |     pub frequency: f32,
[INFO] [stdout]   |         ^^^^^^^^^
[INFO] [stdout] 7 |     pub amplitude: f32,
[INFO] [stdout]   |         ^^^^^^^^^
[INFO] [stdout] 8 |     pub direction: f32,
[INFO] [stdout]   |         ^^^^^^^^^
[INFO] [stdout] 9 |     pub position: Vector<f32>,
[INFO] [stdout]   |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Wood`, `Metal`, and `Glass` are never constructed
[INFO] [stdout]   --> src/models/models.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub enum Material {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] 14 |     Wood { absorption_coefficient: f32 },
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 15 |     Metal { absorption_coefficient: f32 },
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 16 |     Glass { absorption_coefficient: f32 },
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Material` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/models/models.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Engine {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 21 |     pub gravity: Vector<f32>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 22 |     pub physics: PhysicsPipeline,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 23 |     pub integration_parameters: IntegrationParameters,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     pub broad_phase: BroadPhase,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 25 |     pub narrow_phase: NarrowPhase,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 26 |     pub bodies: RigidBodySet,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 27 |     pub colliders: ColliderSet,
[INFO] [stdout] 28 |     pub impulse_joint_set: ImpulseJointSet,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 29 |     pub multibody_joint_set: MultibodyJointSet,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 30 |     pub query_pipeline: QueryPipeline,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 31 |     pub ccd_solver: CCDSolver,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 32 |     pub material_mapping: HashMap<RigidBodyHandle, Material>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 33 |     pub sound_mapping: HashMap<RigidBodyHandle, SoundWave>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 34 |     pub interaction_mapping: HashMap<RigidBodyHandle, Vec<RigidBodyHandle>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/engine/engine.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn interact(wave: &SoundWave, material: &Material) -> SoundWave {
[INFO] [stdout]    | ------------------------------------------------------------------- move the `impl` block outside of this function `interact`
[INFO] [stdout] 12 |     impl Material {
[INFO] [stdout]    |     ^^^^^--------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Material` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: `#[warn(non_local_definitions)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Material` and `SoundWave`
[INFO] [stdout]  --> src/main.rs:4:22
[INFO] [stdout]   |
[INFO] [stdout] 4 | use models::models::{SoundWave, Material};
[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: `ImpulseJoint`
[INFO] [stdout]  --> src/engine/engine.rs:3:16
[INFO] [stdout]   |
[INFO] [stdout] 3 |     CCDSolver, ImpulseJoint, IntegrationParameters, MultibodyJointSet, RigidBodySet,
[INFO] [stdout]   |                ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::thread;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `engine`
[INFO] [stdout]   --> src/tests/tests.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 |     let engine = Engine::new();    }
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_engine`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `body`
[INFO] [stdout]    --> src/engine/engine.rs:139:27
[INFO] [stdout]     |
[INFO] [stdout] 139 |         for (body_handle, body) in self.bodies.iter() {
[INFO] [stdout]     |                           ^^^^ help: if this is intentional, prefix it with an underscore: `_body`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `interacted_wave`
[INFO] [stdout]    --> src/engine/engine.rs:141:21
[INFO] [stdout]     |
[INFO] [stdout] 141 |                 let interacted_wave = interact(wave, &material);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_interacted_wave`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `position`
[INFO] [stdout]  --> src/sound/sound.rs:8:69
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn generate_wave(sample_rate: f32, frequency: f32, volume: f32, position: Vector<f32>) -> Vec<f32> {
[INFO] [stdout]   |                                                                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_position`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `amplitude`
[INFO] [stdout]   --> src/sound/sound.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 20 |     let amplitude: f32 = volume;  // Example calculation for amplitude
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_amplitude`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `direction`
[INFO] [stdout]   --> src/sound/sound.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 |     let direction = Vector::new(1.0, 0.0, 0.0);  // Example default direction
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_direction`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `position`
[INFO] [stdout]   --> src/sound/sound.rs:22:9
[INFO] [stdout]    |
[INFO] [stdout] 22 |     let position: rapier3d::prelude::nalgebra::Matrix<f64, rapier3d::prelude::nalgebra::Const<3>, rapier3d::prelude::nalgebra::Const...
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_position`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:27:9
[INFO] [stdout]    |
[INFO] [stdout] 27 |     let mut wave: Vec<f32> = generate_wave(44100.0, 528.0, 0.5, Vector::new(0.0, 0.0, 0.0));
[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: `sample_rate`
[INFO] [stdout]   --> src/main.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let sample_rate = 44100.0;
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_sample_rate`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `frequency`
[INFO] [stdout]   --> src/main.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 25 |     let frequency = 528.0;
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_frequency`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `interact_mapping`, `step`, `process_sound_wave_interactions`, and `get_material_of_body` are never used
[INFO] [stdout]    --> src/engine/engine.rs:39:12
[INFO] [stdout]     |
[INFO] [stdout]  38 | impl Engine {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout]  39 |     pub fn interact_mapping(&self, wave: &SoundWave, material: &Material) -> SoundWave {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  87 |     pub fn step(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 138 |     pub fn process_sound_wave_interactions(&mut self, wave: &SoundWave) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |    pub fn get_material_of_body(&self, body_handle: RigidBodyHandle) -> Option<Material> {
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Metal` and `Glass` are never constructed
[INFO] [stdout]   --> src/models/models.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub enum Material {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] 14 |     Wood { absorption_coefficient: f32 },
[INFO] [stdout] 15 |     Metal { absorption_coefficient: f32 },
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 16 |     Glass { absorption_coefficient: f32 },
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Material` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/models/models.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub struct Engine {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] 21 |     pub gravity: Vector<f32>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 22 |     pub physics: PhysicsPipeline,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 23 |     pub integration_parameters: IntegrationParameters,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     pub broad_phase: BroadPhase,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 25 |     pub narrow_phase: NarrowPhase,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 26 |     pub bodies: RigidBodySet,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 27 |     pub colliders: ColliderSet,
[INFO] [stdout] 28 |     pub impulse_joint_set: ImpulseJointSet,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 29 |     pub multibody_joint_set: MultibodyJointSet,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 30 |     pub query_pipeline: QueryPipeline,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 31 |     pub ccd_solver: CCDSolver,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 32 |     pub material_mapping: HashMap<RigidBodyHandle, Material>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 33 |     pub sound_mapping: HashMap<RigidBodyHandle, SoundWave>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 34 |     pub interaction_mapping: HashMap<RigidBodyHandle, Vec<RigidBodyHandle>>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: non-local `impl` definition, `impl` blocks should be written at the same level as their item
[INFO] [stdout]   --> src/engine/engine.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn interact(wave: &SoundWave, material: &Material) -> SoundWave {
[INFO] [stdout]    | ------------------------------------------------------------------- move the `impl` block outside of this function `interact`
[INFO] [stdout] 12 |     impl Material {
[INFO] [stdout]    |     ^^^^^--------
[INFO] [stdout]    |          |
[INFO] [stdout]    |          `Material` is not local
[INFO] [stdout]    |
[INFO] [stdout]    = note: an `impl` is never scoped, even when it is nested inside an item, as it may impact type checking outside of that item, which can be the case if neither the trait or the self type are at the same nesting level as the `impl`
[INFO] [stdout]    = note: `#[warn(non_local_definitions)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 25.99s
[INFO] running `Command { std: "docker" "inspect" "c7b2bcb5015dc63c41ee59df2be2eae9088bd0bf3e969e6cc691d7a31d4621ff", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c7b2bcb5015dc63c41ee59df2be2eae9088bd0bf3e969e6cc691d7a31d4621ff", kill_on_drop: false }`
[INFO] [stdout] c7b2bcb5015dc63c41ee59df2be2eae9088bd0bf3e969e6cc691d7a31d4621ff
