[INFO] cloning repository https://github.com/writeoncereadmany/rust-libretro-game
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/writeoncereadmany/rust-libretro-game" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwriteoncereadmany%2Frust-libretro-game", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwriteoncereadmany%2Frust-libretro-game'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 644835293f81f3a087eee6bb4169906b57f92b9c
[INFO] building writeoncereadmany/rust-libretro-game against try#d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 for pr-146237-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fwriteoncereadmany%2Frust-libretro-game" "/workspace/builds/worker-2-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/writeoncereadmany/rust-libretro-game
[INFO] finished tweaking git repo https://github.com/writeoncereadmany/rust-libretro-game
[INFO] tweaked toml for git repo https://github.com/writeoncereadmany/rust-libretro-game written to /workspace/builds/worker-2-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/writeoncereadmany/rust-libretro-game on toolchain d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/writeoncereadmany/rust-libretro-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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fc16b46c33a26aea5885e123434fa4a9ef4a21129f7dc5c08cd1cc119a2b68c4
[INFO] running `Command { std: "docker" "start" "-a" "fc16b46c33a26aea5885e123434fa4a9ef4a21129f7dc5c08cd1cc119a2b68c4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fc16b46c33a26aea5885e123434fa4a9ef4a21129f7dc5c08cd1cc119a2b68c4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fc16b46c33a26aea5885e123434fa4a9ef4a21129f7dc5c08cd1cc119a2b68c4", kill_on_drop: false }`
[INFO] [stdout] fc16b46c33a26aea5885e123434fa4a9ef4a21129f7dc5c08cd1cc119a2b68c4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 37b4643f471aa83765bbf715589de4ba65ffb7ca53283b52c5c93f8660912579
[INFO] running `Command { std: "docker" "start" "-a" "37b4643f471aa83765bbf715589de4ba65ffb7ca53283b52c5c93f8660912579", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling bitflags v2.9.1
[INFO] [stderr]    Compiling clang-sys v1.8.1
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling jobserver v0.1.33
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling libloading v0.8.8
[INFO] [stderr]    Compiling bindgen v0.63.0
[INFO] [stderr]    Compiling home v0.5.11
[INFO] [stderr]    Compiling cc v1.2.32
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]    Compiling lazycell v1.3.0
[INFO] [stderr]    Compiling peeking_take_while v0.1.2
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling zstd-safe v7.2.4
[INFO] [stderr]    Compiling zstd-sys v2.0.15+zstd.1.5.7
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling which v4.4.2
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]    Compiling flate2 v1.1.2
[INFO] [stderr]    Compiling is-terminal v0.4.15
[INFO] [stderr]    Compiling xattr v1.5.1
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling fdeflate v0.3.7
[INFO] [stderr]    Compiling filetime v0.2.25
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling const-str v0.5.7
[INFO] [stderr]    Compiling xml-rs v0.8.27
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling tar v0.4.44
[INFO] [stderr]    Compiling rust-libretro-sys-proc v0.3.2
[INFO] [stderr]    Compiling env_logger v0.10.2
[INFO] [stderr]    Compiling derive v0.1.0 (/opt/rustwide/workdir/derive)
[INFO] [stderr]    Compiling rust-libretro-sys v0.3.2
[INFO] [stderr]    Compiling zstd v0.13.3
[INFO] [stderr]    Compiling tiled v0.14.0
[INFO] [stderr]    Compiling rust-libretro-proc v0.3.2
[INFO] [stderr]    Compiling rust-libretro v0.3.2
[INFO] [stderr]    Compiling example v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/events/timer.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::collections::{BinaryHeap, VecDeque};
[INFO] [stdout]   |                                    ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EventTrait`
[INFO] [stdout]  --> src/events/timer.rs:5:35
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::events::event::{Event, EventTrait, Events};
[INFO] [stdout]   |                                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]   --> src/app/application.rs:54:28
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn play(&mut self, ctx: &mut AudioContext) {}
[INFO] [stdout]    |                            ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_width`
[INFO] [stdout]   --> src/assets/map.rs:85:67
[INFO] [stdout]    |
[INFO] [stdout] 85 |     fn add_spawns(objects: &ObjectLayer, spawns: &mut Vec<Spawn>, tile_width: i32, tile_height: i32) {
[INFO] [stdout]    |                                                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_width`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_height`
[INFO] [stdout]   --> src/assets/map.rs:85:84
[INFO] [stdout]    |
[INFO] [stdout] 85 |     fn add_spawns(objects: &ObjectLayer, spawns: &mut Vec<Spawn>, tile_width: i32, tile_height: i32) {
[INFO] [stdout]    |                                                                                    ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `spawns` is never read
[INFO] [stdout]   --> src/assets/map.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct Map {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] 10 |     pub layers: Vec<Layer>,
[INFO] [stdout] 11 |     pub spawns: Vec<Spawn>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Map` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ScheduleEvent` is never constructed
[INFO] [stdout]  --> src/events/timer.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | struct ScheduleEvent {
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/events/input.rs:9:27
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ButtonReleased(pub JoypadState);
[INFO] [stdout]   |            -------------- ^^^^^^^^^^^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TimerEvent` is never constructed
[INFO] [stdout]   --> src/events/timer.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | struct TimerEvent {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `fire_event` is never used
[INFO] [stdout]   --> src/events/event.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl Events {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn fire_event(&mut self, event: Event) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/events/timer.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl TimerEvent {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 19 |     fn from(instant: Instant, schedule: &ScheduleEvent) -> Self {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Timer` is never constructed
[INFO] [stdout]   --> src/events/timer.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct Timer {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `on_event`, `clear_schedule`, `elapse`, and `has_pending_events` are never used
[INFO] [stdout]   --> src/events/timer.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 53 | impl Timer {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 54 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn on_event(&mut self, event: &Event) {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn clear_schedule(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn elapse(&mut self, dt: &Duration, events: &mut Events) {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 77 |     fn has_pending_events(&self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/events/input.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct InputState(pub JoypadState);
[INFO] [stdout]    |            ---------- ^^^^^^^^^^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `LEFT` and `RIGHT` are never constructed
[INFO] [stdout]  --> src/renderer/spritefont.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub enum HorizontalAlignment {
[INFO] [stdout]   |          ------------------- variants in this enum
[INFO] [stdout] 6 |     LEFT,
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 7 |     CENTER,
[INFO] [stdout] 8 |     RIGHT,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `TOP` and `BOTTOM` are never constructed
[INFO] [stdout]   --> src/renderer/spritefont.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum VerticalAlignment {
[INFO] [stdout]    |          ----------------- variants in this enum
[INFO] [stdout] 12 |     TOP,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 13 |     MIDDLE,
[INFO] [stdout] 14 |     BOTTOM,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw_sprite` is never used
[INFO] [stdout]   --> src/renderer/renderer.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Renderer {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn draw_sprite(&mut self, sprite: &Sprite, x: i32, y: i32, flip_x: bool) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `tile_type` is never read
[INFO] [stdout]   --> src/assets/map.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Tile {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 25 |     pub sprite: Sprite,
[INFO] [stdout] 26 |     pub tile_type: Option<String>
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Tile` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `object_type`, `x`, and `y` are never read
[INFO] [stdout]   --> src/assets/map.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub struct Spawn {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 31 |     object_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 32 |     x: i32,
[INFO] [stdout]    |     ^
[INFO] [stdout] 33 |     y: i32
[INFO] [stdout]    |     ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Spawn` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 22s
[INFO] running `Command { std: "docker" "inspect" "37b4643f471aa83765bbf715589de4ba65ffb7ca53283b52c5c93f8660912579", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "37b4643f471aa83765bbf715589de4ba65ffb7ca53283b52c5c93f8660912579", kill_on_drop: false }`
[INFO] [stdout] 37b4643f471aa83765bbf715589de4ba65ffb7ca53283b52c5c93f8660912579
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1bd02215a6f23ebc579a6543d6f59b0b65548ba8cbd4284fac70ce0b69126f2c
[INFO] running `Command { std: "docker" "start" "-a" "1bd02215a6f23ebc579a6543d6f59b0b65548ba8cbd4284fac70ce0b69126f2c", kill_on_drop: false }`
[INFO] [stderr]    Compiling example v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/events/timer.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::collections::{BinaryHeap, VecDeque};
[INFO] [stdout]   |                                    ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `EventTrait`
[INFO] [stdout]  --> src/events/timer.rs:5:35
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::events::event::{Event, EventTrait, Events};
[INFO] [stdout]   |                                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ctx`
[INFO] [stdout]   --> src/app/application.rs:54:28
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub fn play(&mut self, ctx: &mut AudioContext) {}
[INFO] [stdout]    |                            ^^^ help: if this is intentional, prefix it with an underscore: `_ctx`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_width`
[INFO] [stdout]   --> src/assets/map.rs:85:67
[INFO] [stdout]    |
[INFO] [stdout] 85 |     fn add_spawns(objects: &ObjectLayer, spawns: &mut Vec<Spawn>, tile_width: i32, tile_height: i32) {
[INFO] [stdout]    |                                                                   ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_width`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tile_height`
[INFO] [stdout]   --> src/assets/map.rs:85:84
[INFO] [stdout]    |
[INFO] [stdout] 85 |     fn add_spawns(objects: &ObjectLayer, spawns: &mut Vec<Spawn>, tile_width: i32, tile_height: i32) {
[INFO] [stdout]    |                                                                                    ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tile_height`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `spawns` is never read
[INFO] [stdout]   --> src/assets/map.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct Map {
[INFO] [stdout]    |            --- field in this struct
[INFO] [stdout] 10 |     pub layers: Vec<Layer>,
[INFO] [stdout] 11 |     pub spawns: Vec<Spawn>,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Map` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `tile_type` is never read
[INFO] [stdout]   --> src/assets/map.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Tile {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 25 |     pub sprite: Sprite,
[INFO] [stdout] 26 |     pub tile_type: Option<String>
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Tile` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `object_type`, `x`, and `y` are never read
[INFO] [stdout]   --> src/assets/map.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub struct Spawn {
[INFO] [stdout]    |            ----- fields in this struct
[INFO] [stdout] 31 |     object_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 32 |     x: i32,
[INFO] [stdout]    |     ^
[INFO] [stdout] 33 |     y: i32
[INFO] [stdout]    |     ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Spawn` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `LEFT` and `RIGHT` are never constructed
[INFO] [stdout]  --> src/renderer/spritefont.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub enum HorizontalAlignment {
[INFO] [stdout]   |          ------------------- variants in this enum
[INFO] [stdout] 6 |     LEFT,
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 7 |     CENTER,
[INFO] [stdout] 8 |     RIGHT,
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `TOP` and `BOTTOM` are never constructed
[INFO] [stdout]   --> src/renderer/spritefont.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum VerticalAlignment {
[INFO] [stdout]    |          ----------------- variants in this enum
[INFO] [stdout] 12 |     TOP,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 13 |     MIDDLE,
[INFO] [stdout] 14 |     BOTTOM,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw_sprite` is never used
[INFO] [stdout]   --> src/renderer/renderer.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Renderer {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn draw_sprite(&mut self, sprite: &Sprite, x: i32, y: i32, flip_x: bool) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `fire_event` is never used
[INFO] [stdout]   --> src/events/event.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl Events {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn fire_event(&mut self, event: Event) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]  --> src/events/input.rs:9:27
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct ButtonReleased(pub JoypadState);
[INFO] [stdout]   |            -------------- ^^^^^^^^^^^^^^^
[INFO] [stdout]   |            |
[INFO] [stdout]   |            field in this struct
[INFO] [stdout]   |
[INFO] [stdout]   = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/events/input.rs:12:23
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct InputState(pub JoypadState);
[INFO] [stdout]    |            ---------- ^^^^^^^^^^^^^^^
[INFO] [stdout]    |            |
[INFO] [stdout]    |            field in this struct
[INFO] [stdout]    |
[INFO] [stdout]    = help: consider removing this field
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ScheduleEvent` is never constructed
[INFO] [stdout]  --> src/events/timer.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | struct ScheduleEvent {
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TimerEvent` is never constructed
[INFO] [stdout]   --> src/events/timer.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | struct TimerEvent {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `from` is never used
[INFO] [stdout]   --> src/events/timer.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl TimerEvent {
[INFO] [stdout]    | --------------- associated function in this implementation
[INFO] [stdout] 19 |     fn from(instant: Instant, schedule: &ScheduleEvent) -> Self {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Timer` is never constructed
[INFO] [stdout]   --> src/events/timer.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct Timer {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `on_event`, `clear_schedule`, `elapse`, and `has_pending_events` are never used
[INFO] [stdout]   --> src/events/timer.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 53 | impl Timer {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 54 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn on_event(&mut self, event: &Event) {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn clear_schedule(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn elapse(&mut self, dt: &Duration, events: &mut Events) {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 77 |     fn has_pending_events(&self) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 2.23s
[INFO] running `Command { std: "docker" "inspect" "1bd02215a6f23ebc579a6543d6f59b0b65548ba8cbd4284fac70ce0b69126f2c", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1bd02215a6f23ebc579a6543d6f59b0b65548ba8cbd4284fac70ce0b69126f2c", kill_on_drop: false }`
[INFO] [stdout] 1bd02215a6f23ebc579a6543d6f59b0b65548ba8cbd4284fac70ce0b69126f2c
