[INFO] cloning repository https://github.com/01mk027/rust-ggez-game
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/01mk027/rust-ggez-game" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F01mk027%2Frust-ggez-game", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F01mk027%2Frust-ggez-game'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 13666255dd5a0fdf6ee6d7396c9a1c1bdfdc6806
[INFO] checking 01mk027/rust-ggez-game against try#438eb4c1a1c3841523d7f672601e8adbe04cff28 for pr-147589-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F01mk027%2Frust-ggez-game" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/01mk027/rust-ggez-game
[INFO] finished tweaking git repo https://github.com/01mk027/rust-ggez-game
[INFO] tweaked toml for git repo https://github.com/01mk027/rust-ggez-game written to /workspace/builds/worker-5-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/01mk027/rust-ggez-game on toolchain 438eb4c1a1c3841523d7f672601e8adbe04cff28
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+438eb4c1a1c3841523d7f672601e8adbe04cff28" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/01mk027/rust-ggez-game 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" "+438eb4c1a1c3841523d7f672601e8adbe04cff28" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+438eb4c1a1c3841523d7f672601e8adbe04cff28" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4417047058ab15389ebc59361fa665306990edba65f1305e549809d11f83e23d
[INFO] running `Command { std: "docker" "start" "-a" "4417047058ab15389ebc59361fa665306990edba65f1305e549809d11f83e23d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4417047058ab15389ebc59361fa665306990edba65f1305e549809d11f83e23d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4417047058ab15389ebc59361fa665306990edba65f1305e549809d11f83e23d", kill_on_drop: false }`
[INFO] [stdout] 4417047058ab15389ebc59361fa665306990edba65f1305e549809d11f83e23d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+438eb4c1a1c3841523d7f672601e8adbe04cff28" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 01ac396ecc7cf3c1395e66287f45c34d480dbc88b167a004a388d3aab2a76d4f
[INFO] running `Command { std: "docker" "start" "-a" "01ac396ecc7cf3c1395e66287f45c34d480dbc88b167a004a388d3aab2a76d4f", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.79
[INFO] [stderr]    Compiling libc v0.2.153
[INFO] [stderr]    Compiling pkg-config v0.3.30
[INFO] [stderr]    Compiling version_check v0.9.4
[INFO] [stderr]    Compiling libm v0.2.8
[INFO] [stderr]     Checking arrayvec v0.7.4
[INFO] [stderr]     Checking log v0.4.21
[INFO] [stderr]    Compiling serde v1.0.197
[INFO] [stderr]     Checking lazy_static v1.4.0
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling xml-rs v0.8.19
[INFO] [stderr]     Checking libloading v0.8.3
[INFO] [stderr]    Compiling memoffset v0.6.5
[INFO] [stderr]     Checking smallvec v1.13.1
[INFO] [stderr]    Compiling thiserror v1.0.58
[INFO] [stderr]    Compiling crc32fast v1.4.0
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]     Checking adler v1.0.2
[INFO] [stderr]     Checking zerocopy v0.7.32
[INFO] [stderr]    Compiling crossbeam-utils v0.8.19
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]     Checking miniz_oxide v0.7.2
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]     Checking ttf-parser v0.20.0
[INFO] [stderr]     Checking fdeflate v0.3.4
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling rustix v0.38.31
[INFO] [stderr]     Checking downcast-rs v1.2.0
[INFO] [stderr]     Checking rustc-hash v1.1.0
[INFO] [stderr]    Compiling serde_json v1.0.114
[INFO] [stderr]    Compiling jobserver v0.1.28
[INFO] [stderr]     Checking vec_map v0.8.2
[INFO] [stderr]    Compiling camino v1.1.6
[INFO] [stderr]     Checking byteorder v1.5.0
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]    Compiling cc v1.0.90
[INFO] [stderr]     Checking flate2 v1.0.28
[INFO] [stderr]     Checking scoped-tls v1.0.1
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling slotmap v1.0.7
[INFO] [stderr]    Compiling wayland-sys v0.29.5
[INFO] [stderr]    Compiling libudev-sys v0.1.4
[INFO] [stderr]    Compiling unicase v2.7.0
[INFO] [stderr]    Compiling syn v2.0.52
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling semver v1.0.22
[INFO] [stderr]    Compiling bitflags v2.4.2
[INFO] [stderr]     Checking scopeguard v1.2.0
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.8
[INFO] [stderr]     Checking png v0.17.13
[INFO] [stderr]     Checking crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling error-chain v0.12.4
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]    Compiling pulldown-cmark v0.9.6
[INFO] [stderr]    Compiling khronos-egl v4.1.0
[INFO] [stderr]    Compiling linux-raw-sys v0.4.13
[INFO] [stderr]     Checking allocator-api2 v0.2.16
[INFO] [stderr]    Compiling itoa v1.0.10
[INFO] [stderr]     Checking unicode-width v0.1.11
[INFO] [stderr]     Checking termcolor v1.4.1
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]    Compiling rayon-core v1.12.1
[INFO] [stderr]    Compiling ryu v1.0.17
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]     Checking getrandom v0.2.12
[INFO] [stderr]    Compiling ash v0.37.3+1.3.251
[INFO] [stderr]     Checking bit-set v0.5.3
[INFO] [stderr]     Checking hashbrown v0.14.3
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking nix v0.25.1
[INFO] [stderr]     Checking parking_lot_core v0.9.9
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking euclid v0.22.9
[INFO] [stderr]     Checking spirv v0.2.0+1.5.4
[INFO] [stderr]     Checking crossbeam-deque v0.8.5
[INFO] [stderr]     Checking lock_api v0.4.11
[INFO] [stderr]    Compiling smithay-client-toolkit v0.16.1
[INFO] [stderr]    Compiling nix v0.28.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.2
[INFO] [stderr]     Checking gpu-alloc-types v0.2.0
[INFO] [stderr]     Checking strict-num v0.1.1
[INFO] [stderr]     Checking raw-window-handle v0.5.2
[INFO] [stderr]    Compiling zstd-safe v5.0.2+zstd.1.5.2
[INFO] [stderr]    Compiling memchr v2.7.1
[INFO] [stderr]     Checking ppv-lite86 v0.2.17
[INFO] [stderr]    Compiling same-file v1.0.6
[INFO] [stderr]    Compiling zstd-sys v2.0.9+zstd.1.5.5
[INFO] [stderr]    Compiling bzip2-sys v0.1.11+1.0.8
[INFO] [stderr]     Checking arrayref v0.3.7
[INFO] [stderr]    Compiling wayland-client v0.29.5
[INFO] [stderr]    Compiling wayland-protocols v0.29.5
[INFO] [stderr]     Checking owned_ttf_parser v0.20.0
[INFO] [stderr]     Checking lyon_geom v1.0.5
[INFO] [stderr]     Checking unicode-xid v0.2.4
[INFO] [stderr]    Compiling fastrand v2.0.1
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking ab_glyph v0.2.23
[INFO] [stderr]     Checking xcursor v0.3.5
[INFO] [stderr]     Checking weezl v0.1.8
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]    Compiling walkdir v2.5.0
[INFO] [stderr]     Checking gpu-descriptor v0.2.4
[INFO] [stderr]     Checking gpu-alloc v0.5.4
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking lyon_path v1.0.4
[INFO] [stderr]     Checking wayland-commons v0.29.5
[INFO] [stderr]     Checking memmap2 v0.5.10
[INFO] [stderr]     Checking inotify-sys v0.1.5
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]     Checking wgpu-types v0.16.1
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]     Checking either v1.10.0
[INFO] [stderr]     Checking profiling v1.0.15
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]     Checking jpeg-decoder v0.3.1
[INFO] [stderr]    Compiling bytecount v0.6.7
[INFO] [stderr]     Checking glow v0.12.3
[INFO] [stderr]    Compiling glob v0.3.1
[INFO] [stderr]     Checking gif v0.13.1
[INFO] [stderr]    Compiling tempfile v3.10.1
[INFO] [stderr]     Checking rayon v1.9.0
[INFO] [stderr]     Checking inotify v0.10.2
[INFO] [stderr]     Checking alsa v0.9.0
[INFO] [stderr]     Checking tiff v0.9.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling winit v0.28.7
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking crossbeam-channel v0.5.12
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]    Compiling memoffset v0.8.0
[INFO] [stderr]     Checking float_next_after v1.0.0
[INFO] [stderr]    Compiling bytemuck_derive v1.6.0
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]    Compiling thiserror-impl v1.0.58
[INFO] [stderr]     Checking dasp_sample v0.11.0
[INFO] [stderr]     Checking xi-unicode v0.3.0
[INFO] [stderr]    Compiling gilrs v0.10.5
[INFO] [stderr]    Compiling miniquad v0.4.0
[INFO] [stderr]     Checking mint v0.5.9
[INFO] [stderr]     Checking linked-hash-map v0.5.6
[INFO] [stderr]     Checking option-ext v0.2.0
[INFO] [stderr]     Checking uuid v1.7.0
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking glyph_brush_layout v0.2.3
[INFO] [stderr]     Checking bzip2 v0.4.4
[INFO] [stderr]     Checking gilrs-core v0.5.11
[INFO] [stderr]     Checking wayland-cursor v0.29.5
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]     Checking lyon_tessellation v1.0.13
[INFO] [stderr]     Checking twox-hash v1.6.3
[INFO] [stderr]     Checking lyon_algorithms v1.0.4
[INFO] [stderr]     Checking ordered-float v4.2.0
[INFO] [stderr]     Checking mio v0.8.11
[INFO] [stderr]     Checking hashbrown v0.13.2
[INFO] [stderr]     Checking instant v0.1.12
[INFO] [stderr]     Checking claxon v0.4.3
[INFO] [stderr]     Checking bytemuck v1.15.0
[INFO] [stderr]     Checking hound v3.5.1
[INFO] [stderr]     Checking ttf-parser v0.15.2
[INFO] [stderr]     Checking symphonia-core v0.5.4
[INFO] [stderr]     Checking tiny-skia-path v0.8.4
[INFO] [stderr]     Checking image v0.24.9
[INFO] [stderr]     Checking lyon v1.0.1
[INFO] [stderr]     Checking regex-automata v0.4.6
[INFO] [stderr]     Checking glam v0.24.2
[INFO] [stderr]     Checking glyph_brush_draw_cache v0.1.5
[INFO] [stderr]     Checking naga v0.12.3
[INFO] [stderr]     Checking calloop v0.10.6
[INFO] [stderr]     Checking tiny-skia v0.8.4
[INFO] [stderr]     Checking unescaper v0.1.4
[INFO] [stderr]     Checking glyph_brush v0.7.8
[INFO] [stderr]     Checking directories v5.0.1
[INFO] [stderr]     Checking fontdue v0.7.3
[INFO] [stderr]    Compiling smart-default v0.7.1
[INFO] [stderr]     Checking ordered-float v3.9.2
[INFO] [stderr]     Checking symphonia-metadata v0.5.4
[INFO] [stderr]    Compiling crevice-derive v0.10.0
[INFO] [stderr]     Checking symphonia-bundle-mp3 v0.5.4
[INFO] [stderr]     Checking libudev v0.3.0
[INFO] [stderr]     Checking nix v0.26.4
[INFO] [stderr]     Checking glam v0.21.3
[INFO] [stderr]     Checking quad-rand v0.2.1
[INFO] [stderr]     Checking bumpalo v3.15.4
[INFO] [stderr]     Checking typed-arena v2.0.2
[INFO] [stderr]    Compiling macroquad_macro v0.1.7
[INFO] [stderr]     Checking crevice v0.13.0
[INFO] [stderr]     Checking symphonia v0.5.4
[INFO] [stderr]     Checking rodio v0.17.3
[INFO] [stderr]     Checking iana-time-zone v0.1.60
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]     Checking chrono v0.4.37
[INFO] [stderr]     Checking regex v1.10.3
[INFO] [stderr]     Checking macroquad v0.4.5
[INFO] [stderr]     Checking serialport v4.3.0
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]    Compiling cargo-platform v0.1.7
[INFO] [stderr]     Checking zstd v0.11.2+zstd.1.5.2
[INFO] [stderr]    Compiling cargo_metadata v0.14.2
[INFO] [stderr]     Checking zip v0.6.6
[INFO] [stderr]     Checking wgpu-hal v0.16.2
[INFO] [stderr]    Compiling skeptic v0.13.7
[INFO] [stderr]    Compiling ggez v0.9.3
[INFO] [stderr]     Checking wgpu-core v0.16.1
[INFO] [stderr]     Checking wgpu v0.16.3
[INFO] [stderr]     Checking sctk-adwaita v0.5.4
[INFO] [stderr]     Checking read_from_serial v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `ggez::audio::AudioContext`
[INFO] [stdout]  --> src/main.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use ggez::audio::AudioContext;
[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: `ggez::audio::AudioContext`
[INFO] [stdout]  --> src/main.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use ggez::audio::AudioContext;
[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: `ggez::context::Has`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use ggez::context::Has;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::context::Has`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use ggez::context::Has;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::context::HasMut`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use ggez::context::HasMut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::context::HasMut`
[INFO] [stdout]  --> src/main.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use ggez::context::HasMut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::DrawParam`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use ggez::graphics::DrawParam;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::DrawParam`
[INFO] [stdout]  --> src/main.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use ggez::graphics::DrawParam;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::PxScale`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use ggez::graphics::PxScale;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::PxScale`
[INFO] [stdout]   --> src/main.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use ggez::graphics::PxScale;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::Rect`
[INFO] [stdout]   --> src/main.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ggez::graphics::Rect;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::Rect`
[INFO] [stdout]   --> src/main.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ggez::graphics::Rect;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::color`
[INFO] [stdout]   --> src/main.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use macroquad::color;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `macroquad::color`
[INFO] [stdout]   --> src/main.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use macroquad::color;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serialport::new`
[INFO] [stdout]   --> src/main.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use serialport::new;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serialport::new`
[INFO] [stdout]   --> src/main.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use serialport::new;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serialport::SerialPortBuilder`
[INFO] [stdout]   --> src/main.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use serialport::SerialPortBuilder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serialport::SerialPortBuilder`
[INFO] [stdout]   --> src/main.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use serialport::SerialPortBuilder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any`
[INFO] [stdout]   --> src/main.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use std::any;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/main.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any`
[INFO] [stdout]   --> src/main.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use std::any;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]   --> src/main.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::cell::RefCell;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/main.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]   --> src/main.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use std::ops::Deref;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cell::RefCell`
[INFO] [stdout]   --> src/main.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | use std::cell::RefCell;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/main.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::Deref`
[INFO] [stdout]   --> src/main.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use std::ops::Deref;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]   --> src/main.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::str::FromStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/main.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::RwLock`
[INFO] [stdout]   --> src/main.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | use std::sync::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]   --> src/main.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use std::str::FromStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `First_Target` should have an upper camel case name
[INFO] [stdout]   --> src/main.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | struct First_Target {
[INFO] [stdout]    |        ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `FirstTarget`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::RwLock`
[INFO] [stdout]   --> src/main.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | use std::sync::RwLock;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `First_Target` should have an upper camel case name
[INFO] [stdout]   --> src/main.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | struct First_Target {
[INFO] [stdout]    |        ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `FirstTarget`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::Drawable`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use ggez::graphics::Drawable;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ggez::graphics::Drawable`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use ggez::graphics::Drawable;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:199:29
[INFO] [stdout]     |
[INFO] [stdout] 199 |                         let mut earned_points = &mut self.earned_points;
[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]    --> src/main.rs:200:29
[INFO] [stdout]     |
[INFO] [stdout] 200 |                         let mut destroyed_enemies = &mut self.destroyed_enemies;
[INFO] [stdout]     |                             ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |                         let mut bullets = &mut self.bullets;
[INFO] [stdout]     |                             ----^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:254:29
[INFO] [stdout]     |
[INFO] [stdout] 254 |                         let mut first_target_to_ref = &first_target;
[INFO] [stdout]     |                             ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:255:29
[INFO] [stdout]     |
[INFO] [stdout] 255 |                         let mut ft = first_target.lock().unwrap();
[INFO] [stdout]     |                             ----^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:355:45
[INFO] [stdout]     |
[INFO] [stdout] 355 | ...                   let mut bullets = &mut self.bullets;
[INFO] [stdout]     |                           ----^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `first_target_to_ref`
[INFO] [stdout]    --> src/main.rs:254:29
[INFO] [stdout]     |
[INFO] [stdout] 254 |                         let mut first_target_to_ref = &first_target;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_first_target_to_ref`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ft`
[INFO] [stdout]    --> src/main.rs:255:29
[INFO] [stdout]     |
[INFO] [stdout] 255 |                         let mut ft = first_target.lock().unwrap();
[INFO] [stdout]     |                             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ft`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start`
[INFO] [stdout]    --> src/main.rs:203:29
[INFO] [stdout]     |
[INFO] [stdout] 203 |                         let start = Instant::now();
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_start`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `vx` is assigned to, but never used
[INFO] [stdout]    --> src/main.rs:178:13
[INFO] [stdout]     |
[INFO] [stdout] 178 |         let mut vx: f32 = 0.0;
[INFO] [stdout]     |             ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_vx` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `now`
[INFO] [stdout]    --> src/main.rs:180:13
[INFO] [stdout]     |
[INFO] [stdout] 180 |         let now = SystemTime::now();
[INFO] [stdout]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_now`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `re`
[INFO] [stdout]    --> src/main.rs:188:13
[INFO] [stdout]     |
[INFO] [stdout] 188 |         let re = Regex::new(r"^[0-9]\s+").unwrap();
[INFO] [stdout]     |             ^^ help: if this is intentional, prefix it with an underscore: `_re`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:199:29
[INFO] [stdout]     |
[INFO] [stdout] 199 |                         let mut earned_points = &mut self.earned_points;
[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: `v`
[INFO] [stdout]    --> src/main.rs:191:16
[INFO] [stdout]     |
[INFO] [stdout] 191 |             Ok(v) => {
[INFO] [stdout]     |                ^ help: if this is intentional, prefix it with an underscore: `_v`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:200:29
[INFO] [stdout]     |
[INFO] [stdout] 200 |                         let mut destroyed_enemies = &mut self.destroyed_enemies;
[INFO] [stdout]     |                             ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ss`
[INFO] [stdout]    --> src/main.rs:353:37
[INFO] [stdout]     |
[INFO] [stdout] 353 | ...                   let ss = thread::scope(|s| {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_ss`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `vx` is never read
[INFO] [stdout]    --> src/main.rs:344:29
[INFO] [stdout]     |
[INFO] [stdout] 344 | ...                   vx = (5.0 * ve.parse::<i32>().unwrap() as f32) / 1023.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 `vx` is never read
[INFO] [stdout]    --> src/main.rs:389:33
[INFO] [stdout]     |
[INFO] [stdout] 389 | ...                   vx = 4.5;
[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/main.rs:253:29
[INFO] [stdout]     |
[INFO] [stdout] 253 |                         let mut bullets = &mut self.bullets;
[INFO] [stdout]     |                             ----^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `vx` is never read
[INFO] [stdout]    --> src/main.rs:387:33
[INFO] [stdout]     |
[INFO] [stdout] 387 | ...                   vx = -2.5;
[INFO] [stdout]     |                       ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `vx` is never read
[INFO] [stdout]    --> src/main.rs:385:33
[INFO] [stdout]     |
[INFO] [stdout] 385 | ...                   vx = 0.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/main.rs:254:29
[INFO] [stdout]     |
[INFO] [stdout] 254 |                         let mut first_target_to_ref = &first_target;
[INFO] [stdout]     |                             ----^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:255:29
[INFO] [stdout]     |
[INFO] [stdout] 255 |                         let mut ft = first_target.lock().unwrap();
[INFO] [stdout]     |                             ----^^
[INFO] [stdout]     |                             |
[INFO] [stdout]     |                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:355:45
[INFO] [stdout]     |
[INFO] [stdout] 355 | ...                   let mut bullets = &mut self.bullets;
[INFO] [stdout]     |                           ----^^^^^^^
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `first_target_to_ref`
[INFO] [stdout]    --> src/main.rs:254:29
[INFO] [stdout]     |
[INFO] [stdout] 254 |                         let mut first_target_to_ref = &first_target;
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_first_target_to_ref`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ft`
[INFO] [stdout]    --> src/main.rs:255:29
[INFO] [stdout]     |
[INFO] [stdout] 255 |                         let mut ft = first_target.lock().unwrap();
[INFO] [stdout]     |                             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_ft`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start`
[INFO] [stdout]    --> src/main.rs:203:29
[INFO] [stdout]     |
[INFO] [stdout] 203 |                         let start = Instant::now();
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_start`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `vx` is assigned to, but never used
[INFO] [stdout]    --> src/main.rs:178:13
[INFO] [stdout]     |
[INFO] [stdout] 178 |         let mut vx: f32 = 0.0;
[INFO] [stdout]     |             ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_vx` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `now`
[INFO] [stdout]    --> src/main.rs:180:13
[INFO] [stdout]     |
[INFO] [stdout] 180 |         let now = SystemTime::now();
[INFO] [stdout]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_now`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `re`
[INFO] [stdout]    --> src/main.rs:188:13
[INFO] [stdout]     |
[INFO] [stdout] 188 |         let re = Regex::new(r"^[0-9]\s+").unwrap();
[INFO] [stdout]     |             ^^ help: if this is intentional, prefix it with an underscore: `_re`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `v`
[INFO] [stdout]    --> src/main.rs:191:16
[INFO] [stdout]     |
[INFO] [stdout] 191 |             Ok(v) => {
[INFO] [stdout]     |                ^ help: if this is intentional, prefix it with an underscore: `_v`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ss`
[INFO] [stdout]    --> src/main.rs:353:37
[INFO] [stdout]     |
[INFO] [stdout] 353 | ...                   let ss = thread::scope(|s| {
[INFO] [stdout]     |                           ^^ help: if this is intentional, prefix it with an underscore: `_ss`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `vx` is never read
[INFO] [stdout]    --> src/main.rs:344:29
[INFO] [stdout]     |
[INFO] [stdout] 344 | ...                   vx = (5.0 * ve.parse::<i32>().unwrap() as f32) / 1023.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 `vx` is never read
[INFO] [stdout]    --> src/main.rs:389:33
[INFO] [stdout]     |
[INFO] [stdout] 389 | ...                   vx = 4.5;
[INFO] [stdout]     |                       ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `vx` is never read
[INFO] [stdout]    --> src/main.rs:387:33
[INFO] [stdout]     |
[INFO] [stdout] 387 | ...                   vx = -2.5;
[INFO] [stdout]     |                       ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `vx` is never read
[INFO] [stdout]    --> src/main.rs:385:33
[INFO] [stdout]     |
[INFO] [stdout] 385 | ...                   vx = 0.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/main.rs:472:13
[INFO] [stdout]     |
[INFO] [stdout] 472 |         let mut ft = first_target.lock().unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:533:13
[INFO] [stdout]     |
[INFO] [stdout] 533 |         let mut color_of_target = Color::WHITE;
[INFO] [stdout]     |             ----^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `earned_points_txt_dest`
[INFO] [stdout]    --> src/main.rs:454:13
[INFO] [stdout]     |
[INFO] [stdout] 454 |         let earned_points_txt_dest = Vec2::new(200.0, 100.0);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_earned_points_txt_dest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `first_opponent`
[INFO] [stdout]    --> src/main.rs:473:13
[INFO] [stdout]     |
[INFO] [stdout] 473 |         let first_opponent = graphics::Rect::new(ft.xst, ft.yst, ft.width, ft.height);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_first_opponent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target_animed`
[INFO] [stdout]    --> src/main.rs:476:17
[INFO] [stdout]     |
[INFO] [stdout] 476 |             let target_animed = graphics::Rect::new(tar.xst, tar.yst, tar.width, tar.height);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_animed`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `color_of_target`
[INFO] [stdout]    --> src/main.rs:533:13
[INFO] [stdout]     |
[INFO] [stdout] 533 |         let mut color_of_target = Color::WHITE;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_color_of_target`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:472:13
[INFO] [stdout]     |
[INFO] [stdout] 472 |         let mut ft = first_target.lock().unwrap();
[INFO] [stdout]     |             ----^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:533:13
[INFO] [stdout]     |
[INFO] [stdout] 533 |         let mut color_of_target = Color::WHITE;
[INFO] [stdout]     |             ----^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `earned_points_txt_dest`
[INFO] [stdout]    --> src/main.rs:454:13
[INFO] [stdout]     |
[INFO] [stdout] 454 |         let earned_points_txt_dest = Vec2::new(200.0, 100.0);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_earned_points_txt_dest`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `first_opponent`
[INFO] [stdout]    --> src/main.rs:473:13
[INFO] [stdout]     |
[INFO] [stdout] 473 |         let first_opponent = graphics::Rect::new(ft.xst, ft.yst, ft.width, ft.height);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_first_opponent`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target_animed`
[INFO] [stdout]    --> src/main.rs:476:17
[INFO] [stdout]     |
[INFO] [stdout] 476 |             let target_animed = graphics::Rect::new(tar.xst, tar.yst, tar.width, tar.height);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_target_animed`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `color_of_target`
[INFO] [stdout]    --> src/main.rs:533:13
[INFO] [stdout]     |
[INFO] [stdout] 533 |         let mut color_of_target = Color::WHITE;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_color_of_target`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Vector2` is never used
[INFO] [stdout]   --> src/main.rs:38:6
[INFO] [stdout]    |
[INFO] [stdout] 38 | type Vector2 = Vec2;
[INFO] [stdout]    |      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `Vector2` is never used
[INFO] [stdout]   --> src/main.rs:38:6
[INFO] [stdout]    |
[INFO] [stdout] 38 | type Vector2 = Vec2;
[INFO] [stdout]    |      ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `hp`, `is_accurate_hit`, and `elapsed_time` are never read
[INFO] [stdout]   --> src/main.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 60 | struct First_Target {
[INFO] [stdout]    |        ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     hp: f32,
[INFO] [stdout]    |     ^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |     is_accurate_hit: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 68 |     elapsed_time: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `First_Target` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `hp`, `is_accurate_hit`, and `elapsed_time` are never read
[INFO] [stdout]   --> src/main.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 60 | struct First_Target {
[INFO] [stdout]    |        ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     hp: f32,
[INFO] [stdout]    |     ^^
[INFO] [stdout] ...
[INFO] [stdout] 67 |     is_accurate_hit: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 68 |     elapsed_time: Instant,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `First_Target` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `mass` is never read
[INFO] [stdout]   --> src/main.rs:75:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct Target {
[INFO] [stdout]    |        ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 75 |     mass: f32,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Target` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pos_y` is never read
[INFO] [stdout]    --> src/main.rs:126:5
[INFO] [stdout]     |
[INFO] [stdout] 124 | struct MainState {
[INFO] [stdout]     |        --------- field in this struct
[INFO] [stdout] 125 |     pos_x: f32,
[INFO] [stdout] 126 |     pos_y: f32,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `T` is never used
[INFO] [stdout]    --> src/main.rs:169:6
[INFO] [stdout]     |
[INFO] [stdout] 169 | type T = First_Target;
[INFO] [stdout]     |      ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `mass` is never read
[INFO] [stdout]   --> src/main.rs:75:5
[INFO] [stdout]    |
[INFO] [stdout] 72 | struct Target {
[INFO] [stdout]    |        ------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 75 |     mass: f32,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Target` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pos_y` is never read
[INFO] [stdout]    --> src/main.rs:126:5
[INFO] [stdout]     |
[INFO] [stdout] 124 | struct MainState {
[INFO] [stdout]     |        --------- field in this struct
[INFO] [stdout] 125 |     pos_x: f32,
[INFO] [stdout] 126 |     pos_y: f32,
[INFO] [stdout]     |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `T` is never used
[INFO] [stdout]    --> src/main.rs:169:6
[INFO] [stdout]     |
[INFO] [stdout] 169 | type T = First_Target;
[INFO] [stdout]     |      ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static variable `first_target` should have an upper case name
[INFO] [stdout]    --> src/main.rs:172:16
[INFO] [stdout]     |
[INFO] [stdout] 172 |     static ref first_target: Mutex<First_Target> = Mutex::new(First_Target::new());
[INFO] [stdout]     |                ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 172 -     static ref first_target: Mutex<First_Target> = Mutex::new(First_Target::new());
[INFO] [stdout] 172 +     static ref FIRST_TARGET: Mutex<First_Target> = Mutex::new(First_Target::new());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static variable `targets` should have an upper case name
[INFO] [stdout]    --> src/main.rs:173:16
[INFO] [stdout]     |
[INFO] [stdout] 173 |     static ref targets: Arc<Mutex<Vec<Target>>> = Arc::new(Mutex::new(Vec::new()));
[INFO] [stdout]     |                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 173 -     static ref targets: Arc<Mutex<Vec<Target>>> = Arc::new(Mutex::new(Vec::new()));
[INFO] [stdout] 173 +     static ref TARGETS: Arc<Mutex<Vec<Target>>> = Arc::new(Mutex::new(Vec::new()));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static variable `first_target` should have an upper case name
[INFO] [stdout]    --> src/main.rs:172:16
[INFO] [stdout]     |
[INFO] [stdout] 172 |     static ref first_target: Mutex<First_Target> = Mutex::new(First_Target::new());
[INFO] [stdout]     |                ^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 172 -     static ref first_target: Mutex<First_Target> = Mutex::new(First_Target::new());
[INFO] [stdout] 172 +     static ref FIRST_TARGET: Mutex<First_Target> = Mutex::new(First_Target::new());
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static variable `targets` should have an upper case name
[INFO] [stdout]    --> src/main.rs:173:16
[INFO] [stdout]     |
[INFO] [stdout] 173 |     static ref targets: Arc<Mutex<Vec<Target>>> = Arc::new(Mutex::new(Vec::new()));
[INFO] [stdout]     |                ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 173 -     static ref targets: Arc<Mutex<Vec<Target>>> = Arc::new(Mutex::new(Vec::new()));
[INFO] [stdout] 173 +     static ref TARGETS: Arc<Mutex<Vec<Target>>> = Arc::new(Mutex::new(Vec::new()));
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/main.rs:522:13
[INFO] [stdout]     |
[INFO] [stdout] 522 |             self.assets.fire_sound.play_detached(ctx);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 522 |             let _ = self.assets.fire_sound.play_detached(ctx);
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/main.rs:556:17
[INFO] [stdout]     |
[INFO] [stdout] 556 |                 self.assets.hit_sound.play_detached(ctx);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 556 |                 let _ = self.assets.hit_sound.play_detached(ctx);
[INFO] [stdout]     |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/main.rs:522:13
[INFO] [stdout]     |
[INFO] [stdout] 522 |             self.assets.fire_sound.play_detached(ctx);
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 522 |             let _ = self.assets.fire_sound.play_detached(ctx);
[INFO] [stdout]     |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/main.rs:556:17
[INFO] [stdout]     |
[INFO] [stdout] 556 |                 self.assets.hit_sound.play_detached(ctx);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 556 |                 let _ = self.assets.hit_sound.play_detached(ctx);
[INFO] [stdout]     |                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 34.42s
[INFO] running `Command { std: "docker" "inspect" "01ac396ecc7cf3c1395e66287f45c34d480dbc88b167a004a388d3aab2a76d4f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "01ac396ecc7cf3c1395e66287f45c34d480dbc88b167a004a388d3aab2a76d4f", kill_on_drop: false }`
[INFO] [stdout] 01ac396ecc7cf3c1395e66287f45c34d480dbc88b167a004a388d3aab2a76d4f
