[INFO] cloning repository https://github.com/danbruno/chip8-emulator
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/danbruno/chip8-emulator" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdanbruno%2Fchip8-emulator", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdanbruno%2Fchip8-emulator'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ae5ca20856bc351be3ef07fe7a3c7c0cf2ea4964
[INFO] checking danbruno/chip8-emulator against master#bca37a20bd376ce3fd138e7cdee7fe704e0f8814 for pr-139493-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdanbruno%2Fchip8-emulator" "/workspace/builds/worker-2-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-2-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/danbruno/chip8-emulator
[INFO] finished tweaking git repo https://github.com/danbruno/chip8-emulator
[INFO] tweaked toml for git repo https://github.com/danbruno/chip8-emulator written to /workspace/builds/worker-2-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/danbruno/chip8-emulator on toolchain bca37a20bd376ce3fd138e7cdee7fe704e0f8814
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/danbruno/chip8-emulator 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" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded wayland-sys v0.28.1
[INFO] [stderr]   Downloaded wayland-egl v0.28.1
[INFO] [stderr]   Downloaded wayland-commons v0.28.1
[INFO] [stderr]   Downloaded ppv-lite86 v0.2.9
[INFO] [stderr]   Downloaded wayland-scanner v0.28.1
[INFO] [stderr]   Downloaded instant v0.1.8
[INFO] [stderr]   Downloaded xcursor v0.3.2
[INFO] [stderr]   Downloaded thiserror v1.0.21
[INFO] [stderr]   Downloaded core-graphics v0.22.1
[INFO] [stderr]   Downloaded parking_lot_core v0.8.0
[INFO] [stderr]   Downloaded parking_lot v0.11.0
[INFO] [stderr]   Downloaded cc v1.0.61
[INFO] [stderr]   Downloaded serde v1.0.117
[INFO] [stderr]   Downloaded once_cell v1.4.1
[INFO] [stderr]   Downloaded smallvec v1.4.2
[INFO] [stderr]   Downloaded mio v0.6.22
[INFO] [stderr]   Downloaded wayland-protocols v0.28.1
[INFO] [stderr]   Downloaded smithay-client-toolkit v0.12.0
[INFO] [stderr]   Downloaded glutin v0.25.1
[INFO] [stderr]   Downloaded net2 v0.2.35
[INFO] [stderr]   Downloaded thiserror-impl v1.0.21
[INFO] [stderr]   Downloaded syn v1.0.48
[INFO] [stderr]   Downloaded lock_api v0.4.1
[INFO] [stderr]   Downloaded cloudabi v0.1.0
[INFO] [stderr]   Downloaded libloading v0.6.5
[INFO] [stderr]   Downloaded wayland-client v0.28.1
[INFO] [stderr]   Downloaded winit v0.23.0
[INFO] [stderr]   Downloaded ab_glyph_rasterizer v0.1.4
[INFO] [stderr]   Downloaded wayland-cursor v0.28.1
[INFO] [stderr]   Downloaded libc v0.2.80
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 9654e5ba2b5c1baf5df21cb3de3e378a29ea3839532310411b9f46e12162ac5e
[INFO] running `Command { std: "docker" "start" "-a" "9654e5ba2b5c1baf5df21cb3de3e378a29ea3839532310411b9f46e12162ac5e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "9654e5ba2b5c1baf5df21cb3de3e378a29ea3839532310411b9f46e12162ac5e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "9654e5ba2b5c1baf5df21cb3de3e378a29ea3839532310411b9f46e12162ac5e", kill_on_drop: false }`
[INFO] [stdout] 9654e5ba2b5c1baf5df21cb3de3e378a29ea3839532310411b9f46e12162ac5e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-2-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1a65aba45aee2b7f34b42f40d37605e644de2634f7d1f6ac254268060b617e71
[INFO] running `Command { std: "docker" "start" "-a" "1a65aba45aee2b7f34b42f40d37605e644de2634f7d1f6ac254268060b617e71", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.80
[INFO] [stderr]    Compiling log v0.4.11
[INFO] [stderr]    Compiling nix v0.18.0
[INFO] [stderr]     Checking libloading v0.6.5
[INFO] [stderr]    Compiling wayland-sys v0.28.1
[INFO] [stderr]     Checking smallvec v1.4.2
[INFO] [stderr]    Compiling quote v1.0.7
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]     Checking once_cell v1.4.1
[INFO] [stderr]    Compiling memchr v2.3.4
[INFO] [stderr]     Checking dlib v0.4.2
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]    Compiling nom v5.1.2
[INFO] [stderr]     Checking scoped-tls v1.0.0
[INFO] [stderr]    Compiling wayland-scanner v0.28.1
[INFO] [stderr]     Checking ttf-parser v0.6.2
[INFO] [stderr]    Compiling getrandom v0.1.15
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.4
[INFO] [stderr]    Compiling byteorder v1.3.4
[INFO] [stderr]     Checking instant v0.1.8
[INFO] [stderr]     Checking lock_api v0.4.1
[INFO] [stderr]    Compiling winit v0.23.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.9
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.5
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.7
[INFO] [stderr]     Checking owned_ttf_parser v0.6.0
[INFO] [stderr]     Checking rusttype v0.9.2
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking net2 v0.2.35
[INFO] [stderr]     Checking andrew v0.3.1
[INFO] [stderr]     Checking x11-dl v2.18.5
[INFO] [stderr]     Checking memmap v0.7.0
[INFO] [stderr]     Checking parking_lot_core v0.8.0
[INFO] [stderr]     Checking parking_lot v0.11.0
[INFO] [stderr]     Checking mio v0.6.22
[INFO] [stderr]     Checking rand_core v0.5.1
[INFO] [stderr]    Compiling wayland-client v0.28.1
[INFO] [stderr]    Compiling wayland-protocols v0.28.1
[INFO] [stderr]     Checking raw-window-handle v0.3.3
[INFO] [stderr]     Checking shared_library v0.1.9
[INFO] [stderr]     Checking rand_chacha v0.2.2
[INFO] [stderr]     Checking xcursor v0.3.2
[INFO] [stderr]     Checking osmesa-sys v0.1.2
[INFO] [stderr]     Checking rand v0.7.3
[INFO] [stderr]     Checking mio-extras v2.0.6
[INFO] [stderr]     Checking wayland-commons v0.28.1
[INFO] [stderr]     Checking calloop v0.6.5
[INFO] [stderr]     Checking wayland-cursor v0.28.1
[INFO] [stderr]     Checking wayland-egl v0.28.1
[INFO] [stderr]     Checking smithay-client-toolkit v0.12.0
[INFO] [stderr]     Checking glutin v0.25.1
[INFO] [stderr]     Checking nes_emulator v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/cpu.rs:345:16
[INFO] [stdout]     |
[INFO] [stdout] 345 |             if (self.gpu.screen[i] > 0) {
[INFO] [stdout]     |                ^                      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 345 -             if (self.gpu.screen[i] > 0) {
[INFO] [stdout] 345 +             if self.gpu.screen[i] > 0  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/cpu.rs:352:16
[INFO] [stdout]     |
[INFO] [stdout] 352 |             if (i % 64 == 0) {
[INFO] [stdout]     |                ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 352 -             if (i % 64 == 0) {
[INFO] [stdout] 352 +             if i % 64 == 0  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ElementState`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     ElementState, Event, KeyboardInput, VirtualKeyCode, WindowEvent,
[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: `EventLoop`
[INFO] [stdout]   --> src/main.rs:12:39
[INFO] [stdout]    |
[INFO] [stdout] 12 | use glutin::event_loop::{ControlFlow, EventLoop};
[INFO] [stdout]    |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glutin::window::WindowBuilder`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use glutin::window::WindowBuilder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glutin::ContextBuilder`
[INFO] [stdout]   --> src/main.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use glutin::ContextBuilder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SystemTime`
[INFO] [stdout]   --> src/main.rs:15:17
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::time::{SystemTime, Instant};
[INFO] [stdout]    |                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/cpu.rs:321:13
[INFO] [stdout]     |
[INFO] [stdout] 321 |         let mut erased = 0;
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/cpu.rs:322:13
[INFO] [stdout]     |
[INFO] [stdout] 322 |         let mut coord_x = self.v[x] as usize;
[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/cpu.rs:323:13
[INFO] [stdout]     |
[INFO] [stdout] 323 |         let mut coord_y = self.v[y] as usize;
[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/cpu.rs:324:13
[INFO] [stdout]     |
[INFO] [stdout] 324 |         let mut b:u8 = n as u8;
[INFO] [stdout]     |             ----^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `erased`
[INFO] [stdout]    --> src/cpu.rs:321:13
[INFO] [stdout]     |
[INFO] [stdout] 321 |         let mut erased = 0;
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_erased`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/cpu.rs:324:13
[INFO] [stdout]     |
[INFO] [stdout] 324 |         let mut b:u8 = n as u8;
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/cpu.rs:363:42
[INFO] [stdout]     |
[INFO] [stdout] 363 |     fn check_stored_key_equal(&mut self, x: usize) {
[INFO] [stdout]     |                                          ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/cpu.rs:368:46
[INFO] [stdout]     |
[INFO] [stdout] 368 |     fn check_stored_key_not_equal(&mut self, x: usize) {
[INFO] [stdout]     |                                              ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/gpu.rs:17:28
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |                            ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/gpu.rs:17:35
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |                                   ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/gpu.rs:17:42
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let mut is_maximized = false;
[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:48:9
[INFO] [stdout]    |
[INFO] [stdout] 48 |     let mut frequency = 600; //Hz
[INFO] [stdout]    |         ----^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gpu`
[INFO] [stdout]   --> src/main.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let gpu = Gpu::new();
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_gpu`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_maximized`
[INFO] [stdout]   --> src/main.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let mut is_maximized = false;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_maximized`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WIDTH` is never used
[INFO] [stdout]  --> src/gpu.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub const WIDTH: usize = 64;
[INFO] [stdout]   |           ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEIGHT` is never used
[INFO] [stdout]  --> src/gpu.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub const HEIGHT: usize = 32;
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw` is never used
[INFO] [stdout]   --> src/gpu.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout]  8 | impl Gpu {
[INFO] [stdout]    | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `has_keys` is never used
[INFO] [stdout]   --> src/input.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl Input {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn has_keys(&mut self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/cpu.rs:345:16
[INFO] [stdout]     |
[INFO] [stdout] 345 |             if (self.gpu.screen[i] > 0) {
[INFO] [stdout]     |                ^                      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 345 -             if (self.gpu.screen[i] > 0) {
[INFO] [stdout] 345 +             if self.gpu.screen[i] > 0  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/cpu.rs:352:16
[INFO] [stdout]     |
[INFO] [stdout] 352 |             if (i % 64 == 0) {
[INFO] [stdout]     |                ^           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 352 -             if (i % 64 == 0) {
[INFO] [stdout] 352 +             if i % 64 == 0  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ElementState`
[INFO] [stdout]   --> src/main.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     ElementState, Event, KeyboardInput, VirtualKeyCode, WindowEvent,
[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: `EventLoop`
[INFO] [stdout]   --> src/main.rs:12:39
[INFO] [stdout]    |
[INFO] [stdout] 12 | use glutin::event_loop::{ControlFlow, EventLoop};
[INFO] [stdout]    |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glutin::window::WindowBuilder`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use glutin::window::WindowBuilder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `glutin::ContextBuilder`
[INFO] [stdout]   --> src/main.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use glutin::ContextBuilder;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `SystemTime`
[INFO] [stdout]   --> src/main.rs:15:17
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::time::{SystemTime, Instant};
[INFO] [stdout]    |                 ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 38.91s
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/cpu.rs:321:13
[INFO] [stdout]     |
[INFO] [stdout] 321 |         let mut erased = 0;
[INFO] [stdout]     |             ----^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: nom v5.1.2
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/cpu.rs:322:13
[INFO] [stdout]     |
[INFO] [stdout] 322 |         let mut coord_x = self.v[x] as usize;
[INFO] [stdout]     |             ----^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 3`
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/cpu.rs:323:13
[INFO] [stdout]     |
[INFO] [stdout] 323 |         let mut coord_y = self.v[y] as usize;
[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/cpu.rs:324:13
[INFO] [stdout]     |
[INFO] [stdout] 324 |         let mut b:u8 = n as u8;
[INFO] [stdout]     |             ----^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `erased`
[INFO] [stdout]    --> src/cpu.rs:321:13
[INFO] [stdout]     |
[INFO] [stdout] 321 |         let mut erased = 0;
[INFO] [stdout]     |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_erased`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b`
[INFO] [stdout]    --> src/cpu.rs:324:13
[INFO] [stdout]     |
[INFO] [stdout] 324 |         let mut b:u8 = n as u8;
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_b`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/cpu.rs:363:42
[INFO] [stdout]     |
[INFO] [stdout] 363 |     fn check_stored_key_equal(&mut self, x: usize) {
[INFO] [stdout]     |                                          ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/cpu.rs:368:46
[INFO] [stdout]     |
[INFO] [stdout] 368 |     fn check_stored_key_not_equal(&mut self, x: usize) {
[INFO] [stdout]     |                                              ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]   --> src/gpu.rs:17:28
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |                            ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `y`
[INFO] [stdout]   --> src/gpu.rs:17:35
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |                                   ^ help: if this is intentional, prefix it with an underscore: `_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]   --> src/gpu.rs:17:42
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |                                          ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let mut is_maximized = false;
[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:48:9
[INFO] [stdout]    |
[INFO] [stdout] 48 |     let mut frequency = 600; //Hz
[INFO] [stdout]    |         ----^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `gpu`
[INFO] [stdout]   --> src/main.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 |     let gpu = Gpu::new();
[INFO] [stdout]    |         ^^^ help: if this is intentional, prefix it with an underscore: `_gpu`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_maximized`
[INFO] [stdout]   --> src/main.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 44 |     let mut is_maximized = false;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_maximized`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `WIDTH` is never used
[INFO] [stdout]  --> src/gpu.rs:1:11
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub const WIDTH: usize = 64;
[INFO] [stdout]   |           ^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HEIGHT` is never used
[INFO] [stdout]  --> src/gpu.rs:2:11
[INFO] [stdout]   |
[INFO] [stdout] 2 | pub const HEIGHT: usize = 32;
[INFO] [stdout]   |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `draw` is never used
[INFO] [stdout]   --> src/gpu.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout]  8 | impl Gpu {
[INFO] [stdout]    | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn draw(&mut self, x: u8, y: u8, n: usize) -> u8 {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `has_keys` is never used
[INFO] [stdout]   --> src/input.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl Input {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn has_keys(&mut self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "1a65aba45aee2b7f34b42f40d37605e644de2634f7d1f6ac254268060b617e71", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1a65aba45aee2b7f34b42f40d37605e644de2634f7d1f6ac254268060b617e71", kill_on_drop: false }`
[INFO] [stdout] 1a65aba45aee2b7f34b42f40d37605e644de2634f7d1f6ac254268060b617e71
