[INFO] cloning repository https://github.com/BurritoBandit28/Memory-Game
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/BurritoBandit28/Memory-Game" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBurritoBandit28%2FMemory-Game", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBurritoBandit28%2FMemory-Game'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 356eb046b535f32fae56edff28752d16f3559598
[INFO] checking BurritoBandit28/Memory-Game against master#a26e97be8826d408309fffbd8168362365719f50 for pr-136776
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FBurritoBandit28%2FMemory-Game" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/BurritoBandit28/Memory-Game on toolchain a26e97be8826d408309fffbd8168362365719f50
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+a26e97be8826d408309fffbd8168362365719f50" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking git repo https://github.com/BurritoBandit28/Memory-Game
[INFO] finished tweaking git repo https://github.com/BurritoBandit28/Memory-Game
[INFO] tweaked toml for git repo https://github.com/BurritoBandit28/Memory-Game written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] crate git repo https://github.com/BurritoBandit28/Memory-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" "+a26e97be8826d408309fffbd8168362365719f50" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded symphonia v0.5.4
[INFO] [stderr]   Downloaded uuid-macro-internal v1.10.0
[INFO] [stderr]   Downloaded cc v1.0.94
[INFO] [stderr]   Downloaded symphonia-core v0.5.4
[INFO] [stderr]   Downloaded log-mdc v0.1.0
[INFO] [stderr]   Downloaded built v0.7.4
[INFO] [stderr]   Downloaded ravif v0.11.8
[INFO] [stderr]   Downloaded rgb v0.8.45
[INFO] [stderr]   Downloaded bitstream-io v2.5.0
[INFO] [stderr]   Downloaded windows-core v0.54.0
[INFO] [stderr]   Downloaded log4rs v1.3.0
[INFO] [stderr]   Downloaded cpal v0.15.3
[INFO] [stderr]   Downloaded anyhow v1.0.82
[INFO] [stderr]   Downloaded rodio v0.20.1
[INFO] [stderr]   Downloaded alsa v0.9.1
[INFO] [stderr]   Downloaded oboe-sys v0.6.1
[INFO] [stderr]   Downloaded sdl2 v0.36.0
[INFO] [stderr]   Downloaded symphonia-bundle-mp3 v0.5.4
[INFO] [stderr]   Downloaded target-lexicon v0.12.15
[INFO] [stderr]   Downloaded oboe v0.6.1
[INFO] [stderr]   Downloaded thread-id v4.2.2
[INFO] [stderr]   Downloaded num v0.4.2
[INFO] [stderr]   Downloaded thiserror v1.0.62
[INFO] [stderr]   Downloaded thiserror-impl v1.0.62
[INFO] [stderr]   Downloaded symphonia-metadata v0.5.4
[INFO] [stderr]   Downloaded destructure_traitobject v0.2.0
[INFO] [stderr]   Downloaded unsafe-any-ors v1.0.0
[INFO] [stderr]   Downloaded typemap-ors v1.0.0
[INFO] [stderr]   Downloaded coreaudio-sys v0.2.16
[INFO] [stderr]   Downloaded gjson v0.8.1
[INFO] [stderr]   Downloaded sdl2-sys v0.36.0
[INFO] [stderr]   Downloaded windows v0.54.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3959728d45483eb673ba100a951a6b9f5012970368db2a9e08e0ac9b67c8a5ad" "/opt/rustwide/cargo-home/bin/cargo" "+a26e97be8826d408309fffbd8168362365719f50" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 20a17d151038cb46c2dc2221923b85a799d637f06109c6d41ebd8497b10e6bbe
[INFO] running `Command { std: "docker" "start" "-a" "20a17d151038cb46c2dc2221923b85a799d637f06109c6d41ebd8497b10e6bbe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "20a17d151038cb46c2dc2221923b85a799d637f06109c6d41ebd8497b10e6bbe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "20a17d151038cb46c2dc2221923b85a799d637f06109c6d41ebd8497b10e6bbe", kill_on_drop: false }`
[INFO] [stdout] 20a17d151038cb46c2dc2221923b85a799d637f06109c6d41ebd8497b10e6bbe
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:3959728d45483eb673ba100a951a6b9f5012970368db2a9e08e0ac9b67c8a5ad" "/opt/rustwide/cargo-home/bin/cargo" "+a26e97be8826d408309fffbd8168362365719f50" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6a38caca24139d87c38891e994715acfe368981ce0a089f36f903674cfa7300e
[INFO] running `Command { std: "docker" "start" "-a" "6a38caca24139d87c38891e994715acfe368981ce0a089f36f903674cfa7300e", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.76
[INFO] [stderr]    Compiling autocfg v1.2.0
[INFO] [stderr]    Compiling serde v1.0.204
[INFO] [stderr]     Checking arrayvec v0.7.4
[INFO] [stderr]    Compiling anyhow v1.0.82
[INFO] [stderr]    Compiling thiserror v1.0.62
[INFO] [stderr]     Checking memchr v2.7.4
[INFO] [stderr]     Checking either v1.13.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling built v0.7.4
[INFO] [stderr]    Compiling version-compare v0.1.1
[INFO] [stderr]     Checking smallvec v1.13.2
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]    Compiling num-traits v0.2.18
[INFO] [stderr]    Compiling lock_api v0.4.12
[INFO] [stderr]    Compiling num-bigint v0.4.4
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]    Compiling rav1e v0.7.1
[INFO] [stderr]    Compiling sdl2-sys v0.36.0
[INFO] [stderr]     Checking encoding_rs v0.8.35
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]    Compiling quote v1.0.35
[INFO] [stderr]     Checking itertools v0.12.1
[INFO] [stderr]    Compiling syn v2.0.48
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking bitstream-io v2.5.0
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking v_frame v0.3.8
[INFO] [stderr]    Compiling serde_json v1.0.125
[INFO] [stderr]     Checking destructure_traitobject v0.2.0
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]     Checking unsafe-any-ors v1.0.0
[INFO] [stderr]     Checking alsa v0.9.1
[INFO] [stderr]     Checking indexmap v2.5.0
[INFO] [stderr]     Checking ordered-float v2.10.1
[INFO] [stderr]     Checking tinyvec v1.8.1
[INFO] [stderr]     Checking flume v0.11.0
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]     Checking avif-serialize v0.8.1
[INFO] [stderr]     Checking rgb v0.8.45
[INFO] [stderr]     Checking maybe-rayon v0.1.1
[INFO] [stderr]    Compiling sdl2 v0.36.0
[INFO] [stderr]     Checking dasp_sample v0.11.0
[INFO] [stderr]     Checking unsafe-libyaml v0.2.11
[INFO] [stderr]     Checking exr v1.72.0
[INFO] [stderr]     Checking chrono v0.4.38
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking typemap-ors v1.0.0
[INFO] [stderr]     Checking num-iter v0.1.44
[INFO] [stderr]     Checking num-complex v0.4.5
[INFO] [stderr]     Checking thread-id v4.2.2
[INFO] [stderr]     Checking log-mdc v0.1.0
[INFO] [stderr]     Checking humantime v2.1.0
[INFO] [stderr]     Checking claxon v0.4.3
[INFO] [stderr]     Checking same-file v1.0.6
[INFO] [stderr]     Checking arc-swap v1.7.1
[INFO] [stderr]     Checking hound v3.5.1
[INFO] [stderr]     Checking walkdir v2.5.0
[INFO] [stderr]     Checking num v0.4.2
[INFO] [stderr]     Checking gjson v0.8.1
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling serde_derive v1.0.204
[INFO] [stderr]    Compiling thiserror-impl v1.0.62
[INFO] [stderr]    Compiling profiling-procmacros v1.0.15
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]    Compiling uuid-macro-internal v1.10.0
[INFO] [stderr]     Checking profiling v1.0.15
[INFO] [stderr]     Checking uuid v1.10.0
[INFO] [stderr]     Checking image-webp v0.1.2
[INFO] [stderr]     Checking log v0.4.22
[INFO] [stderr]     Checking serde_yaml v0.9.34+deprecated
[INFO] [stderr]     Checking serde-value v0.7.0
[INFO] [stderr]     Checking symphonia-core v0.5.4
[INFO] [stderr]     Checking av1-grain v0.2.3
[INFO] [stderr]     Checking log4rs v1.3.0
[INFO] [stderr]     Checking symphonia-metadata v0.5.4
[INFO] [stderr]     Checking symphonia-bundle-mp3 v0.5.4
[INFO] [stderr]     Checking symphonia v0.5.4
[INFO] [stderr]     Checking rodio v0.20.1
[INFO] [stderr]     Checking ravif v0.11.8
[INFO] [stderr]     Checking image v0.25.1
[INFO] [stderr]     Checking Memory-Game v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::cmp::PartialEq`
[INFO] [stdout]  --> src/entities/card_entity.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cmp::PartialEq;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/entities/card_entity.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::render::Texture`
[INFO] [stdout]  --> src/entities/card_entity.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::render::Texture;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Entity`
[INFO] [stdout]  --> src/entities.rs:5:21
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::entity::{Entity};
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Pointer`
[INFO] [stdout]  --> src/entity.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt::Pointer;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::DerefMut`
[INFO] [stdout]  --> src/entity.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::DerefMut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `Mutex`
[INFO] [stdout]  --> src/entity.rs:3:17
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                 ^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::EventPollIterator`
[INFO] [stdout]  --> src/entity.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdl2::event::EventPollIterator;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::rect::Rect`
[INFO] [stdout]  --> src/entity.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::rect::Rect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Game`
[INFO] [stdout]  --> src/entity.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::game::Game;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/game.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::BufReader`
[INFO] [stdout]  --> src/game.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::io::BufReader;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::DerefMut`
[INFO] [stdout]  --> src/game.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::ops::DerefMut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::sleep`
[INFO] [stdout]  --> src/game.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::thread::sleep;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Month`
[INFO] [stdout]  --> src/game.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use chrono::Month;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Decoder`, `OutputStreamHandle`, `OutputStream`, and `source::Source`
[INFO] [stdout]  --> src/game.rs:9:13
[INFO] [stdout]   |
[INFO] [stdout] 9 | use rodio::{Decoder, OutputStream, source::Source, OutputStreamHandle};
[INFO] [stdout]   |             ^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::bigint::U32Digits`
[INFO] [stdout]   --> src/game.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use num::bigint::U32Digits;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::C`
[INFO] [stdout]   --> src/game.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use sdl2::keyboard::Keycode::C;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TileGraph`
[INFO] [stdout]   --> src/game.rs:20:27
[INFO] [stdout]    |
[INFO] [stdout] 20 | use crate::level::{Level, TileGraph};
[INFO] [stdout]    |                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `entities` and `sound`
[INFO] [stdout]   --> src/game.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 | use crate::{entities, render, sound};
[INFO] [stdout]    |             ^^^^^^^^          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Turn::Player2`
[INFO] [stdout]   --> src/game.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::game::Turn::Player2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TileSize`
[INFO] [stdout]   --> src/game.rs:29:25
[INFO] [stdout]    |
[INFO] [stdout] 29 | use crate::tile::{Tile, TileSize};
[INFO] [stdout]    |                         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Alignment`
[INFO] [stdout]   --> src/game.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 | use crate::widget::{Alignment, Widget};
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::play_widget::PlayWidget`
[INFO] [stdout]   --> src/game.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use crate::widgets::play_widget::PlayWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Hash` and `Hasher`
[INFO] [stdout]  --> src/render.rs:5:17
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::hash::{Hash, Hasher};
[INFO] [stdout]   |                 ^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::iter::Copied`
[INFO] [stdout]  --> src/render.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::iter::Copied;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Scancode::I`
[INFO] [stdout]  --> src/render.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use sdl2::keyboard::Scancode::I;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::libc::stat`
[INFO] [stdout]   --> src/render.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use sdl2::libc::stat;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::pixels::Color`
[INFO] [stdout]   --> src/render.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use sdl2::pixels::Color;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::render`
[INFO] [stdout]   --> src/render.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::render;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::SystemTime`
[INFO] [stdout]  --> src/utils.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::time::SystemTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Level`, `Metadata`, and `Record`
[INFO] [stdout]  --> src/utils.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{Level, LevelFilter, Metadata, Record};
[INFO] [stdout]   |           ^^^^^               ^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sqrt`
[INFO] [stdout]   --> src/utils.rs:11:20
[INFO] [stdout]    |
[INFO] [stdout] 11 | use num::integer::{sqrt, Roots};
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::pow`
[INFO] [stdout]   --> src/utils.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use num::pow;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::PartialEq`
[INFO] [stdout]  --> src/level.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cmp::PartialEq;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `image::imageops::tile`
[INFO] [stdout]  --> src/level.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use image::imageops::tile;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Canvas`
[INFO] [stdout]  --> src/level.rs:5:20
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdl2::render::{Canvas, Texture, WindowCanvas};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Game`
[INFO] [stdout]  --> src/level.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::game::Game;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::resource_location::ResourceLocation`
[INFO] [stdout]  --> src/level.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::resource_location::ResourceLocation;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::utils::get_dist`
[INFO] [stdout]  --> src/level.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::utils::get_dist;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Scancode::S`
[INFO] [stdout]  --> src/tile.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Scancode::S;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Canvas`
[INFO] [stdout]  --> src/tile.rs:5:20
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdl2::render::{Canvas, Texture, WindowCanvas};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/play_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/play_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::warn`
[INFO] [stdout]  --> src/widgets/enum_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::warn;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/enum_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::err_widget::ErrWidget`
[INFO] [stdout]  --> src/widgets/enum_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::widgets::err_widget::ErrWidget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/err_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/widgets/err_widget.rs:2:18
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::{error, warn};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::clamp`
[INFO] [stdout]  --> src/widgets/score_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use num::clamp;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::entity::Entity`
[INFO] [stdout]  --> src/widgets/score_widget.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::entity::Entity;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::play_widget::PlayWidget`
[INFO] [stdout]   --> src/widgets/score_widget.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::widgets::play_widget::PlayWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> src/widgets/score_widget.rs:96:109
[INFO] [stdout]    |
[INFO] [stdout] 96 |                 d_ass.resource_location = ResourceLocation::new("game", "gui/widgets/debug_background.png");;
[INFO] [stdout]    |                                                                                                             ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::hud_screen::HudScreen`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::screens::hud_screen::HudScreen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::current`
[INFO] [stdout]  --> src/widgets/player_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::thread::current;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/play_again_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/play_again_widget.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::hud_screen::HudScreen`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::screens::hud_screen::HudScreen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::hud_screen::HudScreen`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::screens::hud_screen::HudScreen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widget::Widget`
[INFO] [stdout]   --> src/widgets.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::widget::Widget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/screens/hud_screen.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::Event`
[INFO] [stdout]  --> src/screens/hud_screen.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::event::Event;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Texture` and `WindowCanvas`
[INFO] [stdout]  --> src/screens/hud_screen.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::render::{Texture, WindowCanvas};
[INFO] [stdout]   |                    ^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::play_widget::PlayWidget`
[INFO] [stdout]   --> src/screens/hud_screen.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::widgets::play_widget::PlayWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::score_widget::ScoreWidget`
[INFO] [stdout]   --> src/screens/hud_screen.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::widgets::score_widget::ScoreWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/screens.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Game`
[INFO] [stdout]  --> src/widget.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::game::Game;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/sound.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex`
[INFO] [stdout]  --> src/sound.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `once_cell::sync::OnceCell`
[INFO] [stdout]  --> src/sound.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use once_cell::sync::OnceCell;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rodio::cpal::Stream`
[INFO] [stdout]  --> src/sound.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rodio::cpal::Stream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env`
[INFO] [stdout]   --> src/main.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::{env, fs};
[INFO] [stdout]    |           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]   --> src/main.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::fs::File;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::hash::Hash`
[INFO] [stdout]   --> src/main.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::hash::Hash;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::BufReader`
[INFO] [stdout]   --> src/main.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use std::io::BufReader;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::DerefMut`
[INFO] [stdout]   --> src/main.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::ops::DerefMut;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]   --> src/main.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::path::Path;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::main_menu_screen`
[INFO] [stdout]   --> src/main.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use crate::screens::main_menu_screen;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::entity::Entity`
[INFO] [stdout]   --> src/main.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::entity::Entity;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::clamp`
[INFO] [stdout]   --> src/main.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use num::clamp;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::Event`
[INFO] [stdout]   --> src/main.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use sdl2::event::Event;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode`
[INFO] [stdout]   --> src/main.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use sdl2::keyboard::Keycode;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gjson::Value`
[INFO] [stdout]   --> src/main.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | use gjson::Value;
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::Event::KeyDown`
[INFO] [stdout]   --> src/main.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | use sdl2::event::Event::KeyDown;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CardEntity`
[INFO] [stdout]   --> src/main.rs:40:42
[INFO] [stdout]    |
[INFO] [stdout] 40 | use crate::entities::card_entity::{Card, CardEntity};
[INFO] [stdout]    |                                          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::level::Level`
[INFO] [stdout]   --> src/main.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use crate::level::Level;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::render::AssetData`
[INFO] [stdout]   --> src/main.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use crate::render::AssetData;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widget::Alignment`
[INFO] [stdout]   --> src/main.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | use crate::widget::Alignment;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/main.rs:350:5
[INFO] [stdout]     |
[INFO] [stdout] 350 | /     /// Delta refers to the time taken between showing two frames. This value is often used for physics related operations, as this allow...
[INFO] [stdout] 351 | |     /// You can see that happening in [`Entity::physics`]
[INFO] [stdout]     | |_________________________________________________________^
[INFO] [stdout] 352 |       // initiate delta
[INFO] [stdout] 353 |       let mut delta: f32 = 0.0;
[INFO] [stdout]     |       ------------------------- rustdoc does not generate documentation for statements
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `//` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::PartialEq`
[INFO] [stdout]  --> src/entities/card_entity.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cmp::PartialEq;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/entities/card_entity.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::render::Texture`
[INFO] [stdout]  --> src/entities/card_entity.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::render::Texture;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Entity`
[INFO] [stdout]  --> src/entities.rs:5:21
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::entity::{Entity};
[INFO] [stdout]   |                     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Pointer`
[INFO] [stdout]  --> src/entity.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::fmt::Pointer;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::DerefMut`
[INFO] [stdout]  --> src/entity.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ops::DerefMut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `Mutex`
[INFO] [stdout]  --> src/entity.rs:3:17
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                 ^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::EventPollIterator`
[INFO] [stdout]  --> src/entity.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdl2::event::EventPollIterator;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::rect::Rect`
[INFO] [stdout]  --> src/entity.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use sdl2::rect::Rect;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Game`
[INFO] [stdout]  --> src/entity.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::game::Game;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/game.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::BufReader`
[INFO] [stdout]  --> src/game.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::io::BufReader;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::DerefMut`
[INFO] [stdout]  --> src/game.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::ops::DerefMut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::sleep`
[INFO] [stdout]  --> src/game.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::thread::sleep;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]  --> src/game.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::time::Duration;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Month`
[INFO] [stdout]  --> src/game.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use chrono::Month;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Decoder`, `OutputStreamHandle`, `OutputStream`, and `source::Source`
[INFO] [stdout]  --> src/game.rs:9:13
[INFO] [stdout]   |
[INFO] [stdout] 9 | use rodio::{Decoder, OutputStream, source::Source, OutputStreamHandle};
[INFO] [stdout]   |             ^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::bigint::U32Digits`
[INFO] [stdout]   --> src/game.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use num::bigint::U32Digits;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::C`
[INFO] [stdout]   --> src/game.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use sdl2::keyboard::Keycode::C;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TileGraph`
[INFO] [stdout]   --> src/game.rs:20:27
[INFO] [stdout]    |
[INFO] [stdout] 20 | use crate::level::{Level, TileGraph};
[INFO] [stdout]    |                           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `entities` and `sound`
[INFO] [stdout]   --> src/game.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 | use crate::{entities, render, sound};
[INFO] [stdout]    |             ^^^^^^^^          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Turn::Player2`
[INFO] [stdout]   --> src/game.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::game::Turn::Player2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TileSize`
[INFO] [stdout]   --> src/game.rs:29:25
[INFO] [stdout]    |
[INFO] [stdout] 29 | use crate::tile::{Tile, TileSize};
[INFO] [stdout]    |                         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Alignment`
[INFO] [stdout]   --> src/game.rs:31:21
[INFO] [stdout]    |
[INFO] [stdout] 31 | use crate::widget::{Alignment, Widget};
[INFO] [stdout]    |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::play_widget::PlayWidget`
[INFO] [stdout]   --> src/game.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use crate::widgets::play_widget::PlayWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Hash` and `Hasher`
[INFO] [stdout]  --> src/render.rs:5:17
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::hash::{Hash, Hasher};
[INFO] [stdout]   |                 ^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::iter::Copied`
[INFO] [stdout]  --> src/render.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::iter::Copied;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Scancode::I`
[INFO] [stdout]  --> src/render.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use sdl2::keyboard::Scancode::I;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::libc::stat`
[INFO] [stdout]   --> src/render.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use sdl2::libc::stat;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::pixels::Color`
[INFO] [stdout]   --> src/render.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use sdl2::pixels::Color;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::render`
[INFO] [stdout]   --> src/render.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::render;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::SystemTime`
[INFO] [stdout]  --> src/utils.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::time::SystemTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Level`, `Metadata`, and `Record`
[INFO] [stdout]  --> src/utils.rs:4:11
[INFO] [stdout]   |
[INFO] [stdout] 4 | use log::{Level, LevelFilter, Metadata, Record};
[INFO] [stdout]   |           ^^^^^               ^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sqrt`
[INFO] [stdout]   --> src/utils.rs:11:20
[INFO] [stdout]    |
[INFO] [stdout] 11 | use num::integer::{sqrt, Roots};
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::pow`
[INFO] [stdout]   --> src/utils.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use num::pow;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::PartialEq`
[INFO] [stdout]  --> src/level.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::cmp::PartialEq;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `image::imageops::tile`
[INFO] [stdout]  --> src/level.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use image::imageops::tile;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Canvas`
[INFO] [stdout]  --> src/level.rs:5:20
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdl2::render::{Canvas, Texture, WindowCanvas};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Game`
[INFO] [stdout]  --> src/level.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use crate::game::Game;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::resource_location::ResourceLocation`
[INFO] [stdout]  --> src/level.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::resource_location::ResourceLocation;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::utils::get_dist`
[INFO] [stdout]  --> src/level.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::utils::get_dist;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Scancode::S`
[INFO] [stdout]  --> src/tile.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Scancode::S;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Canvas`
[INFO] [stdout]  --> src/tile.rs:5:20
[INFO] [stdout]   |
[INFO] [stdout] 5 | use sdl2::render::{Canvas, Texture, WindowCanvas};
[INFO] [stdout]   |                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/play_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/play_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::warn`
[INFO] [stdout]  --> src/widgets/enum_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::warn;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/enum_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::err_widget::ErrWidget`
[INFO] [stdout]  --> src/widgets/enum_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::widgets::err_widget::ErrWidget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/err_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `warn`
[INFO] [stdout]  --> src/widgets/err_widget.rs:2:18
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::{error, warn};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::clamp`
[INFO] [stdout]  --> src/widgets/score_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use num::clamp;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::entity::Entity`
[INFO] [stdout]  --> src/widgets/score_widget.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::entity::Entity;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::play_widget::PlayWidget`
[INFO] [stdout]   --> src/widgets/score_widget.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use crate::widgets::play_widget::PlayWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary trailing semicolon
[INFO] [stdout]   --> src/widgets/score_widget.rs:96:109
[INFO] [stdout]    |
[INFO] [stdout] 96 |                 d_ass.resource_location = ResourceLocation::new("game", "gui/widgets/debug_background.png");;
[INFO] [stdout]    |                                                                                                             ^ help: remove this semicolon
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(redundant_semicolons)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::hud_screen::HudScreen`
[INFO] [stdout]  --> src/widgets/quit_widget.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::screens::hud_screen::HudScreen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::current`
[INFO] [stdout]  --> src/widgets/player_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::thread::current;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/play_again_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/play_again_widget.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::hud_screen::HudScreen`
[INFO] [stdout]  --> src/widgets/end_screen_quit_widget.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::screens::hud_screen::HudScreen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode::N`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::keyboard::Keycode::N;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::hud_screen::HudScreen`
[INFO] [stdout]  --> src/widgets/crown_widget.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::screens::hud_screen::HudScreen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widget::Widget`
[INFO] [stdout]   --> src/widgets.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::widget::Widget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/screens/hud_screen.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::Event`
[INFO] [stdout]  --> src/screens/hud_screen.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use sdl2::event::Event;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Texture` and `WindowCanvas`
[INFO] [stdout]  --> src/screens/hud_screen.rs:3:20
[INFO] [stdout]   |
[INFO] [stdout] 3 | use sdl2::render::{Texture, WindowCanvas};
[INFO] [stdout]   |                    ^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::play_widget::PlayWidget`
[INFO] [stdout]   --> src/screens/hud_screen.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::widgets::play_widget::PlayWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widgets::score_widget::ScoreWidget`
[INFO] [stdout]   --> src/screens/hud_screen.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::widgets::score_widget::ScoreWidget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screen::Screen`
[INFO] [stdout]  --> src/screens.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::screen::Screen;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::game::Game`
[INFO] [stdout]  --> src/widget.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::game::Game;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/sound.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Mutex`
[INFO] [stdout]  --> src/sound.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::Mutex;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `once_cell::sync::OnceCell`
[INFO] [stdout]  --> src/sound.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use once_cell::sync::OnceCell;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rodio::cpal::Stream`
[INFO] [stdout]  --> src/sound.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use rodio::cpal::Stream;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `env`
[INFO] [stdout]   --> src/main.rs:17:11
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::{env, fs};
[INFO] [stdout]    |           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]   --> src/main.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::fs::File;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::hash::Hash`
[INFO] [stdout]   --> src/main.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::hash::Hash;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::BufReader`
[INFO] [stdout]   --> src/main.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use std::io::BufReader;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ops::DerefMut`
[INFO] [stdout]   --> src/main.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use std::ops::DerefMut;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::path::Path`
[INFO] [stdout]   --> src/main.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::path::Path;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::screens::main_menu_screen`
[INFO] [stdout]   --> src/main.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | use crate::screens::main_menu_screen;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::entity::Entity`
[INFO] [stdout]   --> src/main.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use crate::entity::Entity;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `num::clamp`
[INFO] [stdout]   --> src/main.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use num::clamp;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::Event`
[INFO] [stdout]   --> src/main.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use sdl2::event::Event;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::keyboard::Keycode`
[INFO] [stdout]   --> src/main.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | use sdl2::keyboard::Keycode;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `gjson::Value`
[INFO] [stdout]   --> src/main.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 | use gjson::Value;
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sdl2::event::Event::KeyDown`
[INFO] [stdout]   --> src/main.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 | use sdl2::event::Event::KeyDown;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `CardEntity`
[INFO] [stdout]   --> src/main.rs:40:42
[INFO] [stdout]    |
[INFO] [stdout] 40 | use crate::entities::card_entity::{Card, CardEntity};
[INFO] [stdout]    |                                          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::level::Level`
[INFO] [stdout]   --> src/main.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use crate::level::Level;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::render::AssetData`
[INFO] [stdout]   --> src/main.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use crate::render::AssetData;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::widget::Alignment`
[INFO] [stdout]   --> src/main.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 | use crate::widget::Alignment;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/main.rs:350:5
[INFO] [stdout]     |
[INFO] [stdout] 350 | /     /// Delta refers to the time taken between showing two frames. This value is often used for physics related operations, as this allow...
[INFO] [stdout] 351 | |     /// You can see that happening in [`Entity::physics`]
[INFO] [stdout]     | |_________________________________________________________^
[INFO] [stdout] 352 |       // initiate delta
[INFO] [stdout] 353 |       let mut delta: f32 = 0.0;
[INFO] [stdout]     |       ------------------------- rustdoc does not generate documentation for statements
[INFO] [stdout]     |
[INFO] [stdout]     = help: use `//` for a plain comment
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `widget::Widget`
[INFO] [stdout]   --> src/main.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | use widget::Widget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Widget`
[INFO] [stdout]   --> src/game.rs:31:32
[INFO] [stdout]    |
[INFO] [stdout] 31 | use crate::widget::{Alignment, Widget};
[INFO] [stdout]    |                                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::entity::Entity`
[INFO] [stdout]  --> src/widgets/player_widget.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::entity::Entity;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `amount`
[INFO] [stdout]   --> src/entities/dummy.rs:33:33
[INFO] [stdout]    |
[INFO] [stdout] 33 |     fn change_health(&mut self, amount: f32) {
[INFO] [stdout]    |                                 ^^^^^^ help: if this is intentional, prefix it with an underscore: `_amount`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `amount`
[INFO] [stdout]   --> src/entities/card_entity.rs:52:33
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn change_health(&mut self, amount: f32) {
[INFO] [stdout]    |                                 ^^^^^^ help: if this is intentional, prefix it with an underscore: `_amount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `delta`
[INFO] [stdout]   --> src/entities/card_entity.rs:60:24
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn tick(&mut self, delta: f32) {
[INFO] [stdout]    |                        ^^^^^ help: if this is intentional, prefix it with an underscore: `_delta`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/entities/card_entity.rs:65:13
[INFO] [stdout]    |
[INFO] [stdout] 65 |         let mut player : &mut dyn Entity;
[INFO] [stdout]    |             ----^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `widget::Widget`
[INFO] [stdout]   --> src/main.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 | use widget::Widget;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rl`
[INFO] [stdout]   --> src/entity.rs:41:41
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn set_resource_location(&mut self, rl : ResourceLocation) {
[INFO] [stdout]    |                                         ^^ help: if this is intentional, prefix it with an underscore: `_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `delta`
[INFO] [stdout]   --> src/entity.rs:46:24
[INFO] [stdout]    |
[INFO] [stdout] 46 |     fn tick(&mut self, delta : f32) {}
[INFO] [stdout]    |                        ^^^^^ help: if this is intentional, prefix it with an underscore: `_delta`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Widget`
[INFO] [stdout]   --> src/game.rs:31:32
[INFO] [stdout]    |
[INFO] [stdout] 31 | use crate::widget::{Alignment, Widget};
[INFO] [stdout]    |                                ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::entity::Entity`
[INFO] [stdout]  --> src/widgets/player_widget.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::entity::Entity;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `amount`
[INFO] [stdout]   --> src/entities/dummy.rs:33:33
[INFO] [stdout]    |
[INFO] [stdout] 33 |     fn change_health(&mut self, amount: f32) {
[INFO] [stdout]    |                                 ^^^^^^ help: if this is intentional, prefix it with an underscore: `_amount`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `amount`
[INFO] [stdout]   --> src/entities/card_entity.rs:52:33
[INFO] [stdout]    |
[INFO] [stdout] 52 |     fn change_health(&mut self, amount: f32) {
[INFO] [stdout]    |                                 ^^^^^^ help: if this is intentional, prefix it with an underscore: `_amount`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ass`
[INFO] [stdout]    --> src/entity.rs:107:34
[INFO] [stdout]     |
[INFO] [stdout] 107 |     fn set_asset_data(&mut self, ass : AssetData) {
[INFO] [stdout]     |                                  ^^^ help: if this is intentional, prefix it with an underscore: `_ass`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dims`
[INFO] [stdout]    --> src/game.rs:106:70
[INFO] [stdout]     |
[INFO] [stdout] 106 |     pub fn cycle(&mut self, delta : f32, mousex : u32, mousey : u32, dims : (u32, u32)) {
[INFO] [stdout]     |                                                                      ^^^^ help: if this is intentional, prefix it with an underscore: `_dims`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `delta`
[INFO] [stdout]   --> src/entities/card_entity.rs:60:24
[INFO] [stdout]    |
[INFO] [stdout] 60 |     fn tick(&mut self, delta: f32) {
[INFO] [stdout]    |                        ^^^^^ help: if this is intentional, prefix it with an underscore: `_delta`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/entities/card_entity.rs:65:13
[INFO] [stdout]    |
[INFO] [stdout] 65 |         let mut player : &mut dyn Entity;
[INFO] [stdout]    |             ----^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rl`
[INFO] [stdout]   --> src/entity.rs:41:41
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn set_resource_location(&mut self, rl : ResourceLocation) {
[INFO] [stdout]    |                                         ^^ help: if this is intentional, prefix it with an underscore: `_rl`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `delta`
[INFO] [stdout]   --> src/entity.rs:46:24
[INFO] [stdout]    |
[INFO] [stdout] 46 |     fn tick(&mut self, delta : f32) {}
[INFO] [stdout]    |                        ^^^^^ help: if this is intentional, prefix it with an underscore: `_delta`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ass`
[INFO] [stdout]    --> src/entity.rs:107:34
[INFO] [stdout]     |
[INFO] [stdout] 107 |     fn set_asset_data(&mut self, ass : AssetData) {
[INFO] [stdout]     |                                  ^^^ help: if this is intentional, prefix it with an underscore: `_ass`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dims`
[INFO] [stdout]    --> src/game.rs:106:70
[INFO] [stdout]     |
[INFO] [stdout] 106 |     pub fn cycle(&mut self, delta : f32, mousex : u32, mousey : u32, dims : (u32, u32)) {
[INFO] [stdout]     |                                                                      ^^^^ help: if this is intentional, prefix it with an underscore: `_dims`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/game.rs:238:13
[INFO] [stdout]     |
[INFO] [stdout] 238 |         let mut card_asset_base = AssetData {
[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/game.rs:256:21
[INFO] [stdout]     |
[INFO] [stdout] 256 |                 let mut card = CardEntity::create(None, {
[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/game.rs:297:17
[INFO] [stdout]     |
[INFO] [stdout] 297 |             let mut level = &mut self.current_level;
[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/game.rs:305:21
[INFO] [stdout]     |
[INFO] [stdout] 305 |                 let mut list = &mut self.entities;
[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/render.rs:129:57
[INFO] [stdout]     |
[INFO] [stdout] 129 | pub fn draw_pp_texture(x: i32, y: i32, ass: &AssetData, mut canvas: &mut WindowCanvas, sf: i32, textures : &HashMap<String, Texture>) {
[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/render.rs:132:9
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let mut id = ass.resource_location.clone();
[INFO] [stdout]     |         ----^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tiles`
[INFO] [stdout]   --> src/level.rs:54:36
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn create_scene_background(tiles : &HashMap<String, Tile>) -> Self {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_tiles`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/level.rs:59:13
[INFO] [stdout]    |
[INFO] [stdout] 59 |         let mut level = Self{
[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/game.rs:238:13
[INFO] [stdout]     |
[INFO] [stdout] 238 |         let mut card_asset_base = AssetData {
[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/game.rs:256:21
[INFO] [stdout]     |
[INFO] [stdout] 256 |                 let mut card = CardEntity::create(None, {
[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/game.rs:297:17
[INFO] [stdout]     |
[INFO] [stdout] 297 |             let mut level = &mut self.current_level;
[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/game.rs:305:21
[INFO] [stdout]     |
[INFO] [stdout] 305 |                 let mut list = &mut self.entities;
[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/render.rs:129:57
[INFO] [stdout]     |
[INFO] [stdout] 129 | pub fn draw_pp_texture(x: i32, y: i32, ass: &AssetData, mut canvas: &mut WindowCanvas, sf: i32, textures : &HashMap<String, Texture>) {
[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/render.rs:132:9
[INFO] [stdout]     |
[INFO] [stdout] 132 |     let mut id = ass.resource_location.clone();
[INFO] [stdout]     |         ----^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `size`
[INFO] [stdout]    --> src/tile.rs:223:13
[INFO] [stdout]     |
[INFO] [stdout] 223 |         let size = self.size.get();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/screen.rs:16:13
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let mut listy = self.get_widgets().get_mut(y);
[INFO] [stdout]    |             ----^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tiles`
[INFO] [stdout]   --> src/level.rs:54:36
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn create_scene_background(tiles : &HashMap<String, Tile>) -> Self {
[INFO] [stdout]    |                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_tiles`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/level.rs:59:13
[INFO] [stdout]    |
[INFO] [stdout] 59 |         let mut level = Self{
[INFO] [stdout]    |             ----^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `events`
[INFO] [stdout]   --> src/screen.rs:37:53
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn cycle(&mut self, mousex : u32, mousey : u32, events: Vec<Event>) {
[INFO] [stdout]    |                                                     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_events`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/screen.rs:42:21
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 let mut coords = w.correct_coords();
[INFO] [stdout]    |                     ----^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dims`
[INFO] [stdout]   --> src/screen.rs:61:102
[INFO] [stdout]    |
[INFO] [stdout] 61 |     fn render(&mut self, textures : &HashMap<String, Texture>, sf : i32, canvas : &mut WindowCanvas, dims : (u32, u32), debug : bool) {
[INFO] [stdout]    |                                                                                                      ^^^^ help: if this is intentional, prefix it with an underscore: `_dims`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tf`
[INFO] [stdout]   --> src/widgets/score_widget.rs:51:32
[INFO] [stdout]    |
[INFO] [stdout] 51 |     fn set_selected(&mut self, tf: bool) {}
[INFO] [stdout]    |                                ^^ help: if this is intentional, prefix it with an underscore: `_tf`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ass`
[INFO] [stdout]   --> src/widgets/player_widget.rs:88:34
[INFO] [stdout]    |
[INFO] [stdout] 88 |     fn set_asset_data(&mut self, ass: AssetData) {
[INFO] [stdout]    |                                  ^^^ help: if this is intentional, prefix it with an underscore: `_ass`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `size`
[INFO] [stdout]    --> src/tile.rs:223:13
[INFO] [stdout]     |
[INFO] [stdout] 223 |         let size = self.size.get();
[INFO] [stdout]     |             ^^^^ help: if this is intentional, prefix it with an underscore: `_size`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/screen.rs:16:13
[INFO] [stdout]    |
[INFO] [stdout] 16 |         let mut listy = self.get_widgets().get_mut(y);
[INFO] [stdout]    |             ----^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `events`
[INFO] [stdout]   --> src/screen.rs:37:53
[INFO] [stdout]    |
[INFO] [stdout] 37 |     fn cycle(&mut self, mousex : u32, mousey : u32, events: Vec<Event>) {
[INFO] [stdout]    |                                                     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_events`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/screen.rs:42:21
[INFO] [stdout]    |
[INFO] [stdout] 42 |                 let mut coords = w.correct_coords();
[INFO] [stdout]    |                     ----^^^^^^
[INFO] [stdout]    |                     |
[INFO] [stdout]    |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dims`
[INFO] [stdout]   --> src/screen.rs:61:102
[INFO] [stdout]    |
[INFO] [stdout] 61 |     fn render(&mut self, textures : &HashMap<String, Texture>, sf : i32, canvas : &mut WindowCanvas, dims : (u32, u32), debug : bool) {
[INFO] [stdout]    |                                                                                                      ^^^^ help: if this is intentional, prefix it with an underscore: `_dims`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tf`
[INFO] [stdout]   --> src/widgets/score_widget.rs:51:32
[INFO] [stdout]    |
[INFO] [stdout] 51 |     fn set_selected(&mut self, tf: bool) {}
[INFO] [stdout]    |                                ^^ help: if this is intentional, prefix it with an underscore: `_tf`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `scale_offset`
[INFO] [stdout]   --> src/main.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let scale_offset = (sdl_ctx.video().unwrap().current_display_mode(0).unwrap().h / scale_factor as i32) - 180;
[INFO] [stdout]    |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_scale_offset`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ass`
[INFO] [stdout]   --> src/widgets/player_widget.rs:88:34
[INFO] [stdout]    |
[INFO] [stdout] 88 |     fn set_asset_data(&mut self, ass: AssetData) {
[INFO] [stdout]    |                                  ^^^ help: if this is intentional, prefix it with an underscore: `_ass`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `scale_offset`
[INFO] [stdout]   --> src/main.rs:69:9
[INFO] [stdout]    |
[INFO] [stdout] 69 |     let scale_offset = (sdl_ctx.video().unwrap().current_display_mode(0).unwrap().h / scale_factor as i32) - 180;
[INFO] [stdout]    |         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_scale_offset`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:89:9
[INFO] [stdout]    |
[INFO] [stdout] 89 |     let mut canvas = &mut window.into_canvas().build().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:101:13
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut path = String::from(dir.unwrap().path().to_str().unwrap()).replace("\\", "/");
[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:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut path = String::from(dir.unwrap().path().to_str().unwrap()).replace("\\", "/");
[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:240:25
[INFO] [stdout]     |
[INFO] [stdout] 240 |                     let mut collison_box : Option<(u32,u32)>;
[INFO] [stdout]     |                         ----^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `uuid` and `game` are never read
[INFO] [stdout]   --> src/entities/dummy.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub struct DummyEntity {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     uuid : Uuid,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 14 |     game : *mut Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `uuid` and `turn` are never read
[INFO] [stdout]   --> src/entities/card_entity.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct CardEntity {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 21 |     uuid : Uuid,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     turn: Turn,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_resource_location` is never used
[INFO] [stdout]    --> src/entities/card_entity.rs:234:12
[INFO] [stdout]     |
[INFO] [stdout] 222 | impl Card {
[INFO] [stdout]     | --------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn get_resource_location(&self) -> ResourceLocation {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_health`, `change_health`, `set_resource_location`, `get_index`, `set_velocity`, and `set_asset_data` are never used
[INFO] [stdout]    --> src/entity.rs:30:8
[INFO] [stdout]     |
[INFO] [stdout] 13  | pub trait Entity {
[INFO] [stdout]     |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 30  |     fn get_health(&mut self) -> f32;
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39  |     fn change_health(&mut self, amount : f32);
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 40  |
[INFO] [stdout] 41  |     fn set_resource_location(&mut self, rl : ResourceLocation) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53  |     fn get_index(&self) -> usize;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61  |     fn set_velocity(&mut self, velocity : (f32, f32));
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     fn set_asset_data(&mut self, ass : AssetData) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `clone` is never used
[INFO] [stdout]   --> src/game.rs:70:19
[INFO] [stdout]    |
[INFO] [stdout] 69 | impl Turn {
[INFO] [stdout]    | --------- method in this implementation
[INFO] [stdout] 70 |     pub(crate) fn clone(&self) -> Turn {
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_turn` is never used
[INFO] [stdout]    --> src/game.rs:394:12
[INFO] [stdout]     |
[INFO] [stdout] 103 | impl Game {
[INFO] [stdout]     | --------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 394 |     pub fn get_turn(&mut self) -> Turn {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_x`, `get_y`, `set_x`, and `set_y` are never used
[INFO] [stdout]   --> src/render.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | impl Dimensions {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] 52 |     pub fn get_x(&self) -> u32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55 |     pub fn get_y(&self) -> u32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn set_x(&mut self, x : u32) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn set_y(&mut self, y : u32) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mul_vec` is never used
[INFO] [stdout]   --> src/utils.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub fn mul_vec(vec : &mut (f32, f32), val : f32) {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalise_vec` is never used
[INFO] [stdout]   --> src/utils.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn normalise_vec(vec : (f32, f32)) -> (f32,f32) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_dist` is never used
[INFO] [stdout]    --> src/utils.rs:126:8
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub fn get_dist(a : &(f32, f32), b : &(f32, f32)) -> u32 {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_tile` is never used
[INFO] [stdout]   --> src/level.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Level {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn get_tile(&mut self, size : TileSize, coordinates: (f32, f32)) -> Tile {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `connections` is never read
[INFO] [stdout]   --> src/level.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub struct TileGraph {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 78 |     nodes : HashMap<(i32, i32), Tile>,
[INFO] [stdout] 79 |     connections : HashMap<(i32,i32), Vec<((i32,i32), u32)>>,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `append`, `append_from_wolrd_space`, `get_tile`, `build_connections`, and `path_to` are never used
[INFO] [stdout]    --> src/level.rs:86:12
[INFO] [stdout]     |
[INFO] [stdout] 83  | impl TileGraph {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 86  |     pub fn append(&mut self, tile : Tile,value : (i32, i32), connections : Vec<((i32, i32), u32)>) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn append_from_wolrd_space(&mut self, tile : Tile,value : (i32, i32), connections : Vec<((i32, i32), u32)>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn get_tile(&mut self, x : i32, y : i32) -> Tile {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 150 |     pub fn build_connections(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn path_to(&mut self, x : i32, y : i32, tx : i32, ty : i32) -> Vec<(i32, i32)> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `create_none`, `create_nav`, `get_name`, `get_resource_location`, `get_size`, and `get_type` are never used
[INFO] [stdout]    --> src/tile.rs:177:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl Tile {
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn create_none(size : TileSize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn create_nav() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn get_name(&mut self) -> String {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 244 |     pub fn get_resource_location(&mut self) -> ResourceLocation {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 248 |     pub fn get_size(self) -> TileSize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub fn get_type(&mut self) -> TileType {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_game` is never used
[INFO] [stdout]   --> src/screen.rs:29:8
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Screen {
[INFO] [stdout]    |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 29 |     fn set_game(&mut self, game : *mut Game);
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `game` is never read
[INFO] [stdout]   --> src/widgets/enum_widget.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct EnumWidget<T : WidgetEnum> {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     game : *mut Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `get_value` and `create` are never used
[INFO] [stdout]   --> src/widgets/enum_widget.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl<T : WidgetEnum + 'static + Clone> EnumWidget<T> {
[INFO] [stdout]    | ---------------------------------------------------- associated items in this implementation
[INFO] [stdout] 22 |
[INFO] [stdout] 23 |     fn get_value(&mut self) -> T {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn create(alignment: Alignment, x: i32, y: i32, game: *mut Game, enumt : T) -> Box<dyn Widget> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `empty` is never used
[INFO] [stdout]   --> src/widgets/err_widget.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl ErrWidget {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 20 |     pub fn empty() -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `create` is never used
[INFO] [stdout]   --> src/widgets/err_widget.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 43 | impl ErrWidget {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 44 |     pub fn create(alignment: Alignment, x : i32, y : i32, game : *mut Game) -> Box<Self>
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `selected` and `score` are never read
[INFO] [stdout]   --> src/widgets/score_widget.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct ScoreWidget {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 14 |     selected : bool,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |     score : u32
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `create` is never used
[INFO] [stdout]   --> src/widgets/score_widget.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl ScoreWidget {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 23 |     pub fn create(alignment: Alignment, x : i32, y : i32, game : *mut Game) -> Box<Self>
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_screen_coordinates`, `set_asset_data`, `get_resource_location`, `set_allignment`, `get_game`, and `return_enum_int` are never used
[INFO] [stdout]   --> src/widget.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub trait Widget {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 25 |     fn set_screen_coordinates(&mut self, x : i32, y : i32);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn set_asset_data(&mut self, ass : AssetData);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn get_resource_location(&mut self) -> ResourceLocation;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 72 |     fn set_allignment(&mut self, alignment: Alignment);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     fn get_game(&mut self);
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 76 |
[INFO] [stdout] 77 |     fn return_enum_int(&mut self) -> Option<usize> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `TOP`, `BOTTOM`, `CENTRE`, and `NONE` are never constructed
[INFO] [stdout]   --> src/widget.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub enum Alignment {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 95 |     TOP,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 96 |     BOTTOM,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 97 |     CENTRE,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 98 |     NONE
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `parse` is never used
[INFO] [stdout]    --> src/widget.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 101 | impl Alignment {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] 102 |     pub fn parse(val : String) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `resource_location` is never read
[INFO] [stdout]   --> src/sound.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Sound {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] 12 |     pub path : String,
[INFO] [stdout] 13 |     pub resource_location : ResourceLocation
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused borrow that must be used
[INFO] [stdout]   --> src/main.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 86 |     &window.set_mouse_grab(true);
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the borrow produces a value
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let _ = &window.set_mouse_grab(true);
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:89:9
[INFO] [stdout]    |
[INFO] [stdout] 89 |     let mut canvas = &mut window.into_canvas().build().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:101:13
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let mut path = String::from(dir.unwrap().path().to_str().unwrap()).replace("\\", "/");
[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:138:13
[INFO] [stdout]     |
[INFO] [stdout] 138 |         let mut path = String::from(dir.unwrap().path().to_str().unwrap()).replace("\\", "/");
[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:240:25
[INFO] [stdout]     |
[INFO] [stdout] 240 |                     let mut collison_box : Option<(u32,u32)>;
[INFO] [stdout]     |                         ----^^^^^^^^^^^^
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `uuid` and `game` are never read
[INFO] [stdout]   --> src/entities/dummy.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub struct DummyEntity {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 13 |     uuid : Uuid,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 14 |     game : *mut Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `uuid` and `turn` are never read
[INFO] [stdout]   --> src/entities/card_entity.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub struct CardEntity {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 21 |     uuid : Uuid,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     turn: Turn,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_resource_location` is never used
[INFO] [stdout]    --> src/entities/card_entity.rs:234:12
[INFO] [stdout]     |
[INFO] [stdout] 222 | impl Card {
[INFO] [stdout]     | --------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn get_resource_location(&self) -> ResourceLocation {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_health`, `change_health`, `set_resource_location`, `get_index`, `set_velocity`, and `set_asset_data` are never used
[INFO] [stdout]    --> src/entity.rs:30:8
[INFO] [stdout]     |
[INFO] [stdout] 13  | pub trait Entity {
[INFO] [stdout]     |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 30  |     fn get_health(&mut self) -> f32;
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39  |     fn change_health(&mut self, amount : f32);
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 40  |
[INFO] [stdout] 41  |     fn set_resource_location(&mut self, rl : ResourceLocation) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53  |     fn get_index(&self) -> usize;
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61  |     fn set_velocity(&mut self, velocity : (f32, f32));
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     fn set_asset_data(&mut self, ass : AssetData) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `clone` is never used
[INFO] [stdout]   --> src/game.rs:70:19
[INFO] [stdout]    |
[INFO] [stdout] 69 | impl Turn {
[INFO] [stdout]    | --------- method in this implementation
[INFO] [stdout] 70 |     pub(crate) fn clone(&self) -> Turn {
[INFO] [stdout]    |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_turn` is never used
[INFO] [stdout]    --> src/game.rs:394:12
[INFO] [stdout]     |
[INFO] [stdout] 103 | impl Game {
[INFO] [stdout]     | --------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 394 |     pub fn get_turn(&mut self) -> Turn {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_x`, `get_y`, `set_x`, and `set_y` are never used
[INFO] [stdout]   --> src/render.rs:52:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | impl Dimensions {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] 52 |     pub fn get_x(&self) -> u32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55 |     pub fn get_y(&self) -> u32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn set_x(&mut self, x : u32) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub fn set_y(&mut self, y : u32) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mul_vec` is never used
[INFO] [stdout]   --> src/utils.rs:16:8
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub fn mul_vec(vec : &mut (f32, f32), val : f32) {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalise_vec` is never used
[INFO] [stdout]   --> src/utils.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn normalise_vec(vec : (f32, f32)) -> (f32,f32) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_dist` is never used
[INFO] [stdout]    --> src/utils.rs:126:8
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub fn get_dist(a : &(f32, f32), b : &(f32, f32)) -> u32 {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_tile` is never used
[INFO] [stdout]   --> src/level.rs:36:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl Level {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn get_tile(&mut self, size : TileSize, coordinates: (f32, f32)) -> Tile {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `connections` is never read
[INFO] [stdout]   --> src/level.rs:79:5
[INFO] [stdout]    |
[INFO] [stdout] 77 | pub struct TileGraph {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 78 |     nodes : HashMap<(i32, i32), Tile>,
[INFO] [stdout] 79 |     connections : HashMap<(i32,i32), Vec<((i32,i32), u32)>>,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `append`, `append_from_wolrd_space`, `get_tile`, `build_connections`, and `path_to` are never used
[INFO] [stdout]    --> src/level.rs:86:12
[INFO] [stdout]     |
[INFO] [stdout] 83  | impl TileGraph {
[INFO] [stdout]     | -------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 86  |     pub fn append(&mut self, tile : Tile,value : (i32, i32), connections : Vec<((i32, i32), u32)>) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn append_from_wolrd_space(&mut self, tile : Tile,value : (i32, i32), connections : Vec<((i32, i32), u32)>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn get_tile(&mut self, x : i32, y : i32) -> Tile {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 150 |     pub fn build_connections(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 192 |     pub fn path_to(&mut self, x : i32, y : i32, tx : i32, ty : i32) -> Vec<(i32, i32)> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `create_none`, `create_nav`, `get_name`, `get_resource_location`, `get_size`, and `get_type` are never used
[INFO] [stdout]    --> src/tile.rs:177:12
[INFO] [stdout]     |
[INFO] [stdout] 143 | impl Tile {
[INFO] [stdout]     | --------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn create_none(size : TileSize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn create_nav() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn get_name(&mut self) -> String {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 244 |     pub fn get_resource_location(&mut self) -> ResourceLocation {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 248 |     pub fn get_size(self) -> TileSize {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub fn get_type(&mut self) -> TileType {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_game` is never used
[INFO] [stdout]   --> src/screen.rs:29:8
[INFO] [stdout]    |
[INFO] [stdout] 8  | pub trait Screen {
[INFO] [stdout]    |           ------ method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 29 |     fn set_game(&mut self, game : *mut Game);
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `game` is never read
[INFO] [stdout]   --> src/widgets/enum_widget.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct EnumWidget<T : WidgetEnum> {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     game : *mut Game,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `get_value` and `create` are never used
[INFO] [stdout]   --> src/widgets/enum_widget.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl<T : WidgetEnum + 'static + Clone> EnumWidget<T> {
[INFO] [stdout]    | ---------------------------------------------------- associated items in this implementation
[INFO] [stdout] 22 |
[INFO] [stdout] 23 |     fn get_value(&mut self) -> T {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     pub fn create(alignment: Alignment, x: i32, y: i32, game: *mut Game, enumt : T) -> Box<dyn Widget> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `empty` is never used
[INFO] [stdout]   --> src/widgets/err_widget.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl ErrWidget {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 20 |     pub fn empty() -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `create` is never used
[INFO] [stdout]   --> src/widgets/err_widget.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 43 | impl ErrWidget {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] 44 |     pub fn create(alignment: Alignment, x : i32, y : i32, game : *mut Game) -> Box<Self>
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `selected` and `score` are never read
[INFO] [stdout]   --> src/widgets/score_widget.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct ScoreWidget {
[INFO] [stdout]    |            ----------- fields in this struct
[INFO] [stdout] 14 |     selected : bool,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |     score : u32
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `create` is never used
[INFO] [stdout]   --> src/widgets/score_widget.rs:23:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl ScoreWidget {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 23 |     pub fn create(alignment: Alignment, x : i32, y : i32, game : *mut Game) -> Box<Self>
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_screen_coordinates`, `set_asset_data`, `get_resource_location`, `set_allignment`, `get_game`, and `return_enum_int` are never used
[INFO] [stdout]   --> src/widget.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub trait Widget {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 25 |     fn set_screen_coordinates(&mut self, x : i32, y : i32);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn set_asset_data(&mut self, ass : AssetData);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn get_resource_location(&mut self) -> ResourceLocation;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 72 |     fn set_allignment(&mut self, alignment: Alignment);
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     fn get_game(&mut self);
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 76 |
[INFO] [stdout] 77 |     fn return_enum_int(&mut self) -> Option<usize> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `TOP`, `BOTTOM`, `CENTRE`, and `NONE` are never constructed
[INFO] [stdout]   --> src/widget.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 92 | pub enum Alignment {
[INFO] [stdout]    |          --------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 95 |     TOP,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 96 |     BOTTOM,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 97 |     CENTRE,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 98 |     NONE
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `parse` is never used
[INFO] [stdout]    --> src/widget.rs:102:12
[INFO] [stdout]     |
[INFO] [stdout] 101 | impl Alignment {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] 102 |     pub fn parse(val : String) -> Self {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `resource_location` is never read
[INFO] [stdout]   --> src/sound.rs:13:9
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct Sound {
[INFO] [stdout]    |            ----- field in this struct
[INFO] [stdout] 12 |     pub path : String,
[INFO] [stdout] 13 |     pub resource_location : ResourceLocation
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused borrow that must be used
[INFO] [stdout]   --> src/main.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 86 |     &window.set_mouse_grab(true);
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ the borrow produces a value
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let _ = &window.set_mouse_grab(true);
[INFO] [stdout]    |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Entity::set_coords` that must be used
[INFO] [stdout]    --> src/game.rs:232:9
[INFO] [stdout]     |
[INFO] [stdout] 232 |         dummy_player.set_coords((0.0, 0.0));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 232 |         let _ = dummy_player.set_coords((0.0, 0.0));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `Entity::set_coords` that must be used
[INFO] [stdout]    --> src/game.rs:232:9
[INFO] [stdout]     |
[INFO] [stdout] 232 |         dummy_player.set_coords((0.0, 0.0));
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 232 |         let _ = dummy_player.set_coords((0.0, 0.0));
[INFO] [stdout]     |         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 59.48s
[INFO] running `Command { std: "docker" "inspect" "6a38caca24139d87c38891e994715acfe368981ce0a089f36f903674cfa7300e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6a38caca24139d87c38891e994715acfe368981ce0a089f36f903674cfa7300e", kill_on_drop: false }`
[INFO] [stdout] 6a38caca24139d87c38891e994715acfe368981ce0a089f36f903674cfa7300e
