[INFO] cloning repository https://github.com/nathanleiby/bevy-jam-4
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/nathanleiby/bevy-jam-4" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnathanleiby%2Fbevy-jam-4", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnathanleiby%2Fbevy-jam-4'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4da545dc4b87db7832f31eacd9d4d5852431e2e6
[INFO] checking nathanleiby/bevy-jam-4 against 1.95.0-beta.7 for beta-1.95-4
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnathanleiby%2Fbevy-jam-4" "/workspace/builds/worker-0-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/nathanleiby/bevy-jam-4
[INFO] finished tweaking git repo https://github.com/nathanleiby/bevy-jam-4
[INFO] tweaked toml for git repo https://github.com/nathanleiby/bevy-jam-4 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/nathanleiby/bevy-jam-4 on toolchain 1.95.0-beta.7
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0-beta.7" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/nathanleiby/bevy-jam-4 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-beta.7" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0-beta.7" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8d739d4c08a92193f93152b6659ce59bab091634b9d31209b86af69d69a229d6
[INFO] running `Command { std: "docker" "start" "-a" "8d739d4c08a92193f93152b6659ce59bab091634b9d31209b86af69d69a229d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8d739d4c08a92193f93152b6659ce59bab091634b9d31209b86af69d69a229d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8d739d4c08a92193f93152b6659ce59bab091634b9d31209b86af69d69a229d6", kill_on_drop: false }`
[INFO] [stdout] 8d739d4c08a92193f93152b6659ce59bab091634b9d31209b86af69d69a229d6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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-beta.7" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d2b1abd84f0fdf312f682fe74f5b7eedb7a0ca638fbbc8e5e2eade59a953c965
[INFO] running `Command { std: "docker" "start" "-a" "d2b1abd84f0fdf312f682fe74f5b7eedb7a0ca638fbbc8e5e2eade59a953c965", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.69
[INFO] [stderr]    Compiling serde v1.0.190
[INFO] [stderr]    Compiling libc v0.2.149
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]     Checking once_cell v1.18.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.16
[INFO] [stderr]     Checking log v0.4.20
[INFO] [stderr]     Checking zerocopy v0.7.18
[INFO] [stderr]     Checking allocator-api2 v0.2.16
[INFO] [stderr]    Compiling thiserror v1.0.50
[INFO] [stderr]     Checking memchr v2.6.4
[INFO] [stderr]    Compiling ahash v0.8.6
[INFO] [stderr]     Checking pin-project-lite v0.2.13
[INFO] [stderr]    Compiling hashbrown v0.14.3
[INFO] [stderr]    Compiling futures-core v0.3.29
[INFO] [stderr]    Compiling toml_datetime v0.6.5
[INFO] [stderr]     Checking mint v0.5.9
[INFO] [stderr]    Compiling winnow v0.5.17
[INFO] [stderr]     Checking tracing-core v0.1.32
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]     Checking futures-io v0.3.29
[INFO] [stderr]    Compiling slab v0.4.9
[INFO] [stderr]     Checking fastrand v2.0.1
[INFO] [stderr]     Checking waker-fn v1.1.1
[INFO] [stderr]     Checking fastrand v1.9.0
[INFO] [stderr]     Checking async-lock v2.8.0
[INFO] [stderr]     Checking async-task v4.5.0
[INFO] [stderr]     Checking nonmax v0.5.3
[INFO] [stderr]     Checking thread_local v1.1.7
[INFO] [stderr]     Checking bevy_ptr v0.12.0
[INFO] [stderr]     Checking futures-lite v1.13.0
[INFO] [stderr]     Checking smol_str v0.2.0
[INFO] [stderr]    Compiling lock_api v0.4.11
[INFO] [stderr]    Compiling parking_lot_core v0.9.9
[INFO] [stderr]     Checking aho-corasick v1.1.2
[INFO] [stderr]     Checking regex-syntax v0.8.2
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking concurrent-queue v2.3.0
[INFO] [stderr]     Checking sharded-slab v0.1.7
[INFO] [stderr]     Checking async-channel v1.9.0
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]     Checking tracing-log v0.1.4
[INFO] [stderr]    Compiling pkg-config v0.3.27
[INFO] [stderr]    Compiling indexmap v2.0.2
[INFO] [stderr]     Checking async-executor v1.6.0
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]     Checking raw-window-handle v0.5.2
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking termcolor v1.3.0
[INFO] [stderr]     Checking unicode-width v0.1.11
[INFO] [stderr]     Checking bevy_tasks v0.12.0
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking num-integer v0.1.45
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]    Compiling syn v2.0.38
[INFO] [stderr]    Compiling getrandom v0.2.10
[INFO] [stderr]    Compiling cc v1.0.83
[INFO] [stderr]    Compiling uuid v1.5.0
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking miniz_oxide v0.7.1
[INFO] [stderr]     Checking num-rational v0.4.1
[INFO] [stderr]     Checking crossbeam-channel v0.5.8
[INFO] [stderr]     Checking accesskit v0.12.1
[INFO] [stderr]     Checking piper v0.2.1
[INFO] [stderr]     Checking fdeflate v0.3.0
[INFO] [stderr]    Compiling async-fs v1.6.0
[INFO] [stderr]     Checking renderdoc-sys v1.0.0
[INFO] [stderr]     Checking glow v0.12.3
[INFO] [stderr]     Checking flate2 v1.0.28
[INFO] [stderr]    Compiling toml_edit v0.20.7
[INFO] [stderr]    Compiling thiserror-core v1.0.38
[INFO] [stderr]     Checking profiling v1.0.11
[INFO] [stderr]     Checking khronos-egl v4.1.0
[INFO] [stderr]     Checking arrayref v0.3.7
[INFO] [stderr]     Checking base64 v0.21.5
[INFO] [stderr]     Checking constgebra v0.1.3
[INFO] [stderr]     Checking async-broadcast v0.5.1
[INFO] [stderr]     Checking regex-syntax v0.7.5
[INFO] [stderr]     Checking png v0.17.10
[INFO] [stderr]     Checking data-encoding v2.4.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling memoffset v0.7.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking percent-encoding v2.3.0
[INFO] [stderr]     Checking ttf-parser v0.19.2
[INFO] [stderr]    Compiling xml-rs v0.8.19
[INFO] [stderr]     Checking euclid v0.22.9
[INFO] [stderr]    Compiling serde_json v1.0.107
[INFO] [stderr]     Checking nix v0.26.4
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling slotmap v1.0.6
[INFO] [stderr]     Checking itoa v1.0.9
[INFO] [stderr]     Checking ryu v1.0.15
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking mio v0.8.9
[INFO] [stderr]    Compiling gilrs v0.10.2
[INFO] [stderr]     Checking grid v0.10.0
[INFO] [stderr]     Checking sysinfo v0.29.10
[INFO] [stderr]    Compiling memoffset v0.9.0
[INFO] [stderr]     Checking regex-automata v0.4.3
[INFO] [stderr]     Checking base64 v0.13.1
[INFO] [stderr]     Checking taffy v0.3.16
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.15
[INFO] [stderr]     Checking encoding_rs v0.8.33
[INFO] [stderr]     Checking tinyvec v1.6.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling semver v1.0.20
[INFO] [stderr]    Compiling paste v1.0.14
[INFO] [stderr]     Checking unicode-normalization v0.1.22
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]    Compiling typenum v1.17.0
[INFO] [stderr]    Compiling x11rb v0.12.0
[INFO] [stderr]    Compiling rayon-core v1.12.0
[INFO] [stderr]     Checking unicode-bidi v0.3.13
[INFO] [stderr]     Checking crossbeam-deque v0.8.3
[INFO] [stderr]     Checking x11rb-protocol v0.12.0
[INFO] [stderr]     Checking idna v0.4.0
[INFO] [stderr]     Checking regex v1.10.2
[INFO] [stderr]     Checking owned_ttf_parser v0.19.0
[INFO] [stderr]     Checking form_urlencoded v1.2.0
[INFO] [stderr]     Checking ab_glyph v0.2.22
[INFO] [stderr]     Checking gethostname v0.3.0
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking glyph_brush_layout v0.2.3
[INFO] [stderr]     Checking num-complex v0.4.4
[INFO] [stderr]    Compiling cpal v0.15.2
[INFO] [stderr]    Compiling anyhow v1.0.75
[INFO] [stderr]     Checking nohash-hasher v0.2.0
[INFO] [stderr]     Checking either v1.9.0
[INFO] [stderr]     Checking alsa v0.7.1
[INFO] [stderr]     Checking url v2.4.1
[INFO] [stderr]    Compiling rustc_version v0.4.0
[INFO] [stderr]     Checking home v0.5.5
[INFO] [stderr]     Checking robust v1.1.0
[INFO] [stderr]    Compiling blake3 v1.5.0
[INFO] [stderr]    Compiling bevy_macro_utils v0.12.0
[INFO] [stderr]    Compiling encase_derive_impl v0.6.1
[INFO] [stderr]     Checking rayon v1.8.0
[INFO] [stderr]     Checking ringbuf v0.3.3
[INFO] [stderr]    Compiling convert_case v0.4.0
[INFO] [stderr]     Checking webbrowser v0.8.12
[INFO] [stderr]     Checking atomic-arena v0.1.1
[INFO] [stderr]     Checking itertools v0.11.0
[INFO] [stderr]     Checking fxhash v0.2.1
[INFO] [stderr]     Checking path-slash v0.2.1
[INFO] [stderr]     Checking pretty-type-name v1.0.1
[INFO] [stderr]    Compiling winit v0.28.7
[INFO] [stderr]    Compiling toml v0.5.11
[INFO] [stderr]    Compiling embed-resource v1.8.0
[INFO] [stderr]     Checking accesskit_winit v0.15.0
[INFO] [stderr]    Compiling bevy_game v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]    Compiling thiserror-core-impl v1.0.38
[INFO] [stderr]    Compiling nalgebra-macros v0.2.1
[INFO] [stderr]    Compiling num-derive v0.3.3
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling serde_derive v1.0.190
[INFO] [stderr]    Compiling bytemuck_derive v1.5.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.50
[INFO] [stderr]    Compiling tracing-attributes v0.1.27
[INFO] [stderr]    Compiling bevy_utils_proc_macros v0.12.0
[INFO] [stderr]    Compiling bevy_reflect_derive v0.12.0
[INFO] [stderr]    Compiling bevy_ecs_macros v0.12.0
[INFO] [stderr]    Compiling bevy_derive v0.12.0
[INFO] [stderr]    Compiling bevy_asset_macros v0.12.0
[INFO] [stderr]    Compiling encase_derive v0.6.1
[INFO] [stderr]    Compiling bevy_render_macros v0.12.0
[INFO] [stderr]    Compiling bevy_encase_derive v0.12.0
[INFO] [stderr]    Compiling gltf-derive v1.3.0
[INFO] [stderr]    Compiling bevy_asset_loader_derive v0.18.0
[INFO] [stderr]    Compiling bevy-inspector-egui-derive v0.21.0
[INFO] [stderr]    Compiling bevy_xpbd_derive v0.1.0
[INFO] [stderr]     Checking ruzstd v0.4.0
[INFO] [stderr]     Checking bytemuck v1.14.0
[INFO] [stderr]     Checking image v0.24.7
[INFO] [stderr]     Checking symphonia-core v0.5.3
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]     Checking ecolor v0.23.0
[INFO] [stderr]     Checking emath v0.23.0
[INFO] [stderr]     Checking symphonia-metadata v0.5.3
[INFO] [stderr]     Checking wide v0.7.13
[INFO] [stderr]     Checking symphonia-utils-xiph v0.5.3
[INFO] [stderr]     Checking symphonia-format-ogg v0.5.3
[INFO] [stderr]     Checking symphonia-codec-vorbis v0.5.3
[INFO] [stderr]     Checking symphonia v0.5.3
[INFO] [stderr]     Checking simba v0.8.1
[INFO] [stderr]     Checking tracing v0.1.40
[INFO] [stderr]     Checking blocking v1.4.1
[INFO] [stderr]     Checking smallvec v1.11.1
[INFO] [stderr]     Checking glam v0.24.2
[INFO] [stderr]     Checking erased-serde v0.3.31
[INFO] [stderr]     Checking bitflags v2.4.1
[INFO] [stderr]     Checking naga v0.13.0
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.2
[INFO] [stderr]     Checking wgpu-types v0.17.0
[INFO] [stderr]     Checking ron v0.8.1
[INFO] [stderr]     Checking tracing-subscriber v0.3.17
[INFO] [stderr]     Checking gilrs-core v0.5.7
[INFO] [stderr]     Checking gpu-descriptor v0.2.4
[INFO] [stderr]     Checking spade v2.4.1
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking gltf-json v1.3.0
[INFO] [stderr]     Checking epaint v0.23.0
[INFO] [stderr]     Checking arboard v3.3.0
[INFO] [stderr]     Checking petgraph v0.6.4
[INFO] [stderr]     Checking egui v0.23.0
[INFO] [stderr]     Checking bevy_utils v0.12.0
[INFO] [stderr]     Checking gltf v1.3.0
[INFO] [stderr]     Checking bevy_math v0.12.0
[INFO] [stderr]     Checking hexasphere v9.1.0
[INFO] [stderr]     Checking encase v0.6.1
[INFO] [stderr]     Checking bevy_mikktspace v0.12.0
[INFO] [stderr]     Checking nalgebra v0.32.3
[INFO] [stderr]     Checking kira v0.8.5
[INFO] [stderr]     Checking bevy_reflect v0.12.0
[INFO] [stderr]     Checking wgpu-hal v0.17.2
[INFO] [stderr]     Checking naga_oil v0.10.0
[INFO] [stderr]     Checking bevy_ecs v0.12.0
[INFO] [stderr]     Checking wgpu-core v0.17.1
[INFO] [stderr]     Checking parry2d v0.13.5
[INFO] [stderr]     Checking wgpu v0.17.1
[INFO] [stderr]     Checking bevy_app v0.12.0
[INFO] [stderr]     Checking bevy_log v0.12.0
[INFO] [stderr]     Checking bevy_core v0.12.0
[INFO] [stderr]     Checking bevy_input v0.12.0
[INFO] [stderr]     Checking bevy_a11y v0.12.0
[INFO] [stderr]     Checking bevy_time v0.12.0
[INFO] [stderr]     Checking bevy_asset v0.12.0
[INFO] [stderr]     Checking bevy_hierarchy v0.12.0
[INFO] [stderr]     Checking bevy_diagnostic v0.12.0
[INFO] [stderr]     Checking bevy_transform v0.12.0
[INFO] [stderr]     Checking bevy_window v0.12.0
[INFO] [stderr]     Checking bevy_gilrs v0.12.0
[INFO] [stderr]     Checking bevy_render v0.12.0
[INFO] [stderr]     Checking bevy_winit v0.12.0
[INFO] [stderr]     Checking bevy_core_pipeline v0.12.0
[INFO] [stderr]     Checking bevy_animation v0.12.0
[INFO] [stderr]     Checking bevy_scene v0.12.0
[INFO] [stderr]     Checking bevy_sprite v0.12.0
[INFO] [stderr]     Checking bevy_pbr v0.12.0
[INFO] [stderr]     Checking bevy_text v0.12.0
[INFO] [stderr]     Checking bevy_ui v0.12.0
[INFO] [stderr]     Checking bevy_gltf v0.12.0
[INFO] [stderr]     Checking bevy_gizmos v0.12.0
[INFO] [stderr]     Checking bevy_internal v0.12.0
[INFO] [stderr]     Checking bevy v0.12.0
[INFO] [stderr]     Checking bevy_egui v0.23.0
[INFO] [stderr]     Checking bevy_xpbd_2d v0.3.2
[INFO] [stderr]     Checking bevy_asset_loader v0.18.0
[INFO] [stderr]     Checking bevy_kira_audio v0.18.0
[INFO] [stderr]     Checking bevy-inspector-egui v0.21.0
[INFO] [stdout] warning: unused import: `bevy::math::Vec3Swizzles`
[INFO] [stdout]  --> src/actions/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::math::Vec3Swizzles; // TIL: https://en.wikipedia.org/wiki/Swizzling_(computer_graphics)
[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: `crate::player::Player`
[INFO] [stdout]  --> src/actions/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::player::Player;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sprite::MaterialMesh2dBundle`
[INFO] [stdout]  --> src/construction.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use bevy::{prelude::*, sprite::MaterialMesh2dBundle};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `math::*`
[INFO] [stdout]  --> src/construction.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use bevy_xpbd_2d::{math::*, prelude::*};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/destruction.rs:7:14
[INFO] [stdout]   |
[INFO] [stdout] 7 |     player::{self, Player},
[INFO] [stdout]   |              ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sprite::MaterialMesh2dBundle`
[INFO] [stdout]  --> src/destruction.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | use bevy::{prelude::*, sprite::MaterialMesh2dBundle};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `math::*`
[INFO] [stdout]   --> src/destruction.rs:10:20
[INFO] [stdout]    |
[INFO] [stdout] 10 | use bevy_xpbd_2d::{math::*, prelude::*};
[INFO] [stdout]    |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `InspectorOptions` and `inspector_options::ReflectInspectorOptions`
[INFO] [stdout]  --> src/goo.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use bevy_inspector_egui::{inspector_options::ReflectInspectorOptions, InspectorOptions};
[INFO] [stdout]   |                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `marbles::Marble`
[INFO] [stdout]  --> src/goo.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::{level::Goal, marbles::Marble, score::ScoreEvent, GameState};
[INFO] [stdout]   |                          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PhysicsDebugPlugin`
[INFO] [stdout]   --> src/lib.rs:27:29
[INFO] [stdout]    |
[INFO] [stdout] 27 | use bevy_xpbd_2d::plugins::{PhysicsDebugPlugin, PhysicsPlugins};
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `bevy::math::Vec3Swizzles`
[INFO] [stdout]  --> src/actions/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use bevy::math::Vec3Swizzles; // TIL: https://en.wikipedia.org/wiki/Swizzling_(computer_graphics)
[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: `crate::player::Player`
[INFO] [stdout]  --> src/actions/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::player::Player;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sprite::MaterialMesh2dBundle`
[INFO] [stdout]  --> src/construction.rs:6:24
[INFO] [stdout]   |
[INFO] [stdout] 6 | use bevy::{prelude::*, sprite::MaterialMesh2dBundle};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `math::*`
[INFO] [stdout]  --> src/construction.rs:7:20
[INFO] [stdout]   |
[INFO] [stdout] 7 | use bevy_xpbd_2d::{math::*, prelude::*};
[INFO] [stdout]   |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/destruction.rs:7:14
[INFO] [stdout]   |
[INFO] [stdout] 7 |     player::{self, Player},
[INFO] [stdout]   |              ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sprite::MaterialMesh2dBundle`
[INFO] [stdout]  --> src/destruction.rs:9:24
[INFO] [stdout]   |
[INFO] [stdout] 9 | use bevy::{prelude::*, sprite::MaterialMesh2dBundle};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `math::*`
[INFO] [stdout]   --> src/destruction.rs:10:20
[INFO] [stdout]    |
[INFO] [stdout] 10 | use bevy_xpbd_2d::{math::*, prelude::*};
[INFO] [stdout]    |                    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `InspectorOptions` and `inspector_options::ReflectInspectorOptions`
[INFO] [stdout]  --> src/goo.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use bevy_inspector_egui::{inspector_options::ReflectInspectorOptions, InspectorOptions};
[INFO] [stdout]   |                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `marbles::Marble`
[INFO] [stdout]  --> src/goo.rs:5:26
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::{level::Goal, marbles::Marble, score::ScoreEvent, GameState};
[INFO] [stdout]   |                          ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PhysicsDebugPlugin`
[INFO] [stdout]   --> src/lib.rs:27:29
[INFO] [stdout]    |
[INFO] [stdout] 27 | use bevy_xpbd_2d::plugins::{PhysicsDebugPlugin, PhysicsPlugins};
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/construction.rs:48:10
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn setup(mut commands: Commands) {
[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: `commands`
[INFO] [stdout]   --> src/construction.rs:48:10
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn setup(mut commands: Commands) {
[INFO] [stdout]    |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/destruction.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     mut commands: Commands,
[INFO] [stdout]    |     ----^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]   --> src/destruction.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     mut commands: Commands,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `marble_mesh`
[INFO] [stdout]   --> src/destruction.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 30 |     let marble_mesh = meshes.add(shape::Circle::new(DESTRUCTION_GOO_RADIUS).into());
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_marble_mesh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `material_red`
[INFO] [stdout]   --> src/destruction.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let material_red = materials.add(ColorMaterial::from(Color::rgb(0.9, 0.1, 0.1)));
[INFO] [stdout]    |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_material_red`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/destruction.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     for x in -marble_scale..marble_scale {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/destruction.rs:36:13
[INFO] [stdout]    |
[INFO] [stdout] 36 |         for y in -marble_scale..marble_scale {
[INFO] [stdout]    |             ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `player_entity_id` is never read
[INFO] [stdout]   --> src/destruction.rs:77:32
[INFO] [stdout]    |
[INFO] [stdout] 77 |     let mut player_entity_id = 0;
[INFO] [stdout]    |                                ^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `goal_entity_id` is never read
[INFO] [stdout]    --> src/goo.rs:118:30
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let mut goal_entity_id = 0;
[INFO] [stdout]     |                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/goo.rs:153:12
[INFO] [stdout]     |
[INFO] [stdout] 153 | fn despawn(mut commands: Commands, goo_query: Query<(Entity, &Transform, &Goo)>, time: Res<Time>) {
[INFO] [stdout]     |            ----^^^^^^^^
[INFO] [stdout]     |            |
[INFO] [stdout]     |            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/goo.rs:153:12
[INFO] [stdout]     |
[INFO] [stdout] 153 | fn despawn(mut commands: Commands, goo_query: Query<(Entity, &Transform, &Goo)>, time: Res<Time>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `goo_query`
[INFO] [stdout]    --> src/goo.rs:153:36
[INFO] [stdout]     |
[INFO] [stdout] 153 | fn despawn(mut commands: Commands, goo_query: Query<(Entity, &Transform, &Goo)>, time: Res<Time>) {
[INFO] [stdout]     |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_goo_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `now`
[INFO] [stdout]    --> src/goo.rs:154:9
[INFO] [stdout]     |
[INFO] [stdout] 154 |     let now = time.elapsed_seconds_f64();
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_now`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/construction.rs:48:10
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn setup(mut commands: Commands) {
[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: `commands`
[INFO] [stdout]   --> src/construction.rs:48:10
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn setup(mut commands: Commands) {
[INFO] [stdout]    |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/destruction.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     mut commands: Commands,
[INFO] [stdout]    |     ----^^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]   --> src/destruction.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     mut commands: Commands,
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `marble_mesh`
[INFO] [stdout]   --> src/destruction.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 30 |     let marble_mesh = meshes.add(shape::Circle::new(DESTRUCTION_GOO_RADIUS).into());
[INFO] [stdout]    |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_marble_mesh`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `material_red`
[INFO] [stdout]   --> src/destruction.rs:31:9
[INFO] [stdout]    |
[INFO] [stdout] 31 |     let material_red = materials.add(ColorMaterial::from(Color::rgb(0.9, 0.1, 0.1)));
[INFO] [stdout]    |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_material_red`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/destruction.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     for x in -marble_scale..marble_scale {
[INFO] [stdout]    |         ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/destruction.rs:36:13
[INFO] [stdout]    |
[INFO] [stdout] 36 |         for y in -marble_scale..marble_scale {
[INFO] [stdout]    |             ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `player_entity_id` is never read
[INFO] [stdout]   --> src/destruction.rs:77:32
[INFO] [stdout]    |
[INFO] [stdout] 77 |     let mut player_entity_id = 0;
[INFO] [stdout]    |                                ^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mesh2`
[INFO] [stdout]   --> src/player.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let mesh2 = meshes.add(shape::Circle::new(PLAYER_RADIUS + 5.).into());
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_mesh2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `material2`
[INFO] [stdout]   --> src/player.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let material2 = materials.add(ColorMaterial::from(Color::rgb(0., 0.8, 0.8)));
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_material2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `marble`
[INFO] [stdout]   --> src/player.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let marble = commands
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_marble`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/player.rs:102:39
[INFO] [stdout]     |
[INFO] [stdout] 102 |     for (marble, mut linear_velocity, mut angular_velocity) in query.iter_mut() {
[INFO] [stdout]     |                                       ----^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                       |
[INFO] [stdout]     |                                       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `angular_velocity`
[INFO] [stdout]    --> src/player.rs:102:39
[INFO] [stdout]     |
[INFO] [stdout] 102 |     for (marble, mut linear_velocity, mut angular_velocity) in query.iter_mut() {
[INFO] [stdout]     |                                       ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_angular_velocity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `goal_entity_id` is never read
[INFO] [stdout]    --> src/goo.rs:118:30
[INFO] [stdout]     |
[INFO] [stdout] 118 |     let mut goal_entity_id = 0;
[INFO] [stdout]     |                              ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/goo.rs:153:12
[INFO] [stdout]     |
[INFO] [stdout] 153 | fn despawn(mut commands: Commands, goo_query: Query<(Entity, &Transform, &Goo)>, time: Res<Time>) {
[INFO] [stdout]     |            ----^^^^^^^^
[INFO] [stdout]     |            |
[INFO] [stdout]     |            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `commands`
[INFO] [stdout]    --> src/goo.rs:153:12
[INFO] [stdout]     |
[INFO] [stdout] 153 | fn despawn(mut commands: Commands, goo_query: Query<(Entity, &Transform, &Goo)>, time: Res<Time>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_commands`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `goo_query`
[INFO] [stdout]    --> src/goo.rs:153:36
[INFO] [stdout]     |
[INFO] [stdout] 153 | fn despawn(mut commands: Commands, goo_query: Query<(Entity, &Transform, &Goo)>, time: Res<Time>) {
[INFO] [stdout]     |                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_goo_query`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `now`
[INFO] [stdout]    --> src/goo.rs:154:9
[INFO] [stdout]     |
[INFO] [stdout] 154 |     let now = time.elapsed_seconds_f64();
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_now`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CONSTRUCTION_GOO_RADIUS` is never used
[INFO] [stdout]   --> src/construction.rs:20:7
[INFO] [stdout]    |
[INFO] [stdout] 20 | const CONSTRUCTION_GOO_RADIUS: f32 = 3.0;
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SPEED` is never used
[INFO] [stdout]  --> src/goo.rs:8:7
[INFO] [stdout]   |
[INFO] [stdout] 8 | const SPEED: f32 = 150.;
[INFO] [stdout]   |       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `RADIUS_MIN` is never used
[INFO] [stdout]  --> src/goo.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const RADIUS_MIN: f32 = 10.;
[INFO] [stdout]   |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SCREEN_HEIGHT` is never used
[INFO] [stdout]   --> src/goo.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const SCREEN_HEIGHT: f32 = 600.;
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SCREEN_WIDTH` is never used
[INFO] [stdout]   --> src/goo.rs:12:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | const SCREEN_WIDTH: f32 = 800.;
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/goo.rs:30:19
[INFO] [stdout]    |
[INFO] [stdout] 30 | struct SpawnTimer(Timer);
[INFO] [stdout]    |        ---------- ^^^^^
[INFO] [stdout]    |        |
[INFO] [stdout]    |        field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `created_at` is never read
[INFO] [stdout]   --> src/goo.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct Goo {
[INFO] [stdout]    |        --- field in this struct
[INFO] [stdout] 35 |     created_at: f64,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `spawn_goo_on_timer` is never used
[INFO] [stdout]   --> src/goo.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn spawn_goo_on_timer(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_one` is never used
[INFO] [stdout]   --> src/level.rs:92:4
[INFO] [stdout]    |
[INFO] [stdout] 92 | fn setup_level_one() {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_two` is never used
[INFO] [stdout]   --> src/level.rs:97:4
[INFO] [stdout]    |
[INFO] [stdout] 97 | fn setup_level_two() {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_three` is never used
[INFO] [stdout]    --> src/level.rs:102:4
[INFO] [stdout]     |
[INFO] [stdout] 102 | fn setup_level_three() {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_four` is never used
[INFO] [stdout]    --> src/level.rs:106:4
[INFO] [stdout]     |
[INFO] [stdout] 106 | fn setup_level_four() {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `playerControlledIDs` should have a snake case name
[INFO] [stdout]   --> src/marbles.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut playerControlledIDs: HashSet<u32> = HashSet::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `player_controlled_ids`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `marbleEntityIDs` should have a snake case name
[INFO] [stdout]    --> src/marbles.rs:100:13
[INFO] [stdout]     |
[INFO] [stdout] 100 |     let mut marbleEntityIDs: HashSet<u32> = HashSet::new();
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `marble_entity_ids`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mesh2`
[INFO] [stdout]   --> src/player.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 35 |     let mesh2 = meshes.add(shape::Circle::new(PLAYER_RADIUS + 5.).into());
[INFO] [stdout]    |         ^^^^^ help: if this is intentional, prefix it with an underscore: `_mesh2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `material2`
[INFO] [stdout]   --> src/player.rs:36:9
[INFO] [stdout]    |
[INFO] [stdout] 36 |     let material2 = materials.add(ColorMaterial::from(Color::rgb(0., 0.8, 0.8)));
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_material2`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `marble`
[INFO] [stdout]   --> src/player.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 |     let marble = commands
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_marble`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/player.rs:102:39
[INFO] [stdout]     |
[INFO] [stdout] 102 |     for (marble, mut linear_velocity, mut angular_velocity) in query.iter_mut() {
[INFO] [stdout]     |                                       ----^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                                       |
[INFO] [stdout]     |                                       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `angular_velocity`
[INFO] [stdout]    --> src/player.rs:102:39
[INFO] [stdout]     |
[INFO] [stdout] 102 |     for (marble, mut linear_velocity, mut angular_velocity) in query.iter_mut() {
[INFO] [stdout]     |                                       ^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_angular_velocity`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Checking mobile v0.1.0 (/opt/rustwide/workdir/mobile)
[INFO] [stdout] warning: constant `CONSTRUCTION_GOO_RADIUS` is never used
[INFO] [stdout]   --> src/construction.rs:20:7
[INFO] [stdout]    |
[INFO] [stdout] 20 | const CONSTRUCTION_GOO_RADIUS: f32 = 3.0;
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SPEED` is never used
[INFO] [stdout]  --> src/goo.rs:8:7
[INFO] [stdout]   |
[INFO] [stdout] 8 | const SPEED: f32 = 150.;
[INFO] [stdout]   |       ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `RADIUS_MIN` is never used
[INFO] [stdout]  --> src/goo.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const RADIUS_MIN: f32 = 10.;
[INFO] [stdout]   |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SCREEN_HEIGHT` is never used
[INFO] [stdout]   --> src/goo.rs:11:7
[INFO] [stdout]    |
[INFO] [stdout] 11 | const SCREEN_HEIGHT: f32 = 600.;
[INFO] [stdout]    |       ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SCREEN_WIDTH` is never used
[INFO] [stdout]   --> src/goo.rs:12:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | const SCREEN_WIDTH: f32 = 800.;
[INFO] [stdout]    |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/goo.rs:30:19
[INFO] [stdout]    |
[INFO] [stdout] 30 | struct SpawnTimer(Timer);
[INFO] [stdout]    |        ---------- ^^^^^
[INFO] [stdout]    |        |
[INFO] [stdout]    |        field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `created_at` is never read
[INFO] [stdout]   --> src/goo.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 34 | struct Goo {
[INFO] [stdout]    |        --- field in this struct
[INFO] [stdout] 35 |     created_at: f64,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `spawn_goo_on_timer` is never used
[INFO] [stdout]   --> src/goo.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn spawn_goo_on_timer(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_one` is never used
[INFO] [stdout]   --> src/level.rs:92:4
[INFO] [stdout]    |
[INFO] [stdout] 92 | fn setup_level_one() {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_two` is never used
[INFO] [stdout]   --> src/level.rs:97:4
[INFO] [stdout]    |
[INFO] [stdout] 97 | fn setup_level_two() {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_three` is never used
[INFO] [stdout]    --> src/level.rs:102:4
[INFO] [stdout]     |
[INFO] [stdout] 102 | fn setup_level_three() {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `setup_level_four` is never used
[INFO] [stdout]    --> src/level.rs:106:4
[INFO] [stdout]     |
[INFO] [stdout] 106 | fn setup_level_four() {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `playerControlledIDs` should have a snake case name
[INFO] [stdout]   --> src/marbles.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |     let mut playerControlledIDs: HashSet<u32> = HashSet::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `player_controlled_ids`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `marbleEntityIDs` should have a snake case name
[INFO] [stdout]    --> src/marbles.rs:100:13
[INFO] [stdout]     |
[INFO] [stdout] 100 |     let mut marbleEntityIDs: HashSet<u32> = HashSet::new();
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `marble_entity_ids`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [optimized + debuginfo] target(s) in 3m 12s
[INFO] running `Command { std: "docker" "inspect" "d2b1abd84f0fdf312f682fe74f5b7eedb7a0ca638fbbc8e5e2eade59a953c965", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d2b1abd84f0fdf312f682fe74f5b7eedb7a0ca638fbbc8e5e2eade59a953c965", kill_on_drop: false }`
[INFO] [stdout] d2b1abd84f0fdf312f682fe74f5b7eedb7a0ca638fbbc8e5e2eade59a953c965
