[INFO] cloning repository https://github.com/kamui-fin/xines
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/kamui-fin/xines" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkamui-fin%2Fxines", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkamui-fin%2Fxines'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b0f6a38e187f38935c879fd05eec07fa5b024f2d
[INFO] checking kamui-fin/xines against master#c8a31b780d5415358566a20b94912620a3f27067 for pr-139493-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fkamui-fin%2Fxines" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] [stderr] Updating files:  19% (56/281)
Updating files:  20% (57/281)
Updating files:  21% (60/281)
Updating files:  22% (62/281)
Updating files:  23% (65/281)
Updating files:  24% (68/281)
Updating files:  25% (71/281)
Updating files:  26% (74/281)
Updating files:  27% (76/281)
Updating files:  28% (79/281)
Updating files:  29% (82/281)
Updating files:  30% (85/281)
Updating files:  31% (88/281)
Updating files:  32% (90/281)
Updating files:  33% (93/281)
Updating files:  34% (96/281)
Updating files:  35% (99/281)
Updating files:  36% (102/281)
Updating files:  37% (104/281)
Updating files:  38% (107/281)
Updating files:  39% (110/281)
Updating files:  40% (113/281)
Updating files:  41% (116/281)
Updating files:  42% (119/281)
Updating files:  43% (121/281)
Updating files:  44% (124/281)
Updating files:  45% (127/281)
Updating files:  46% (130/281)
Updating files:  47% (133/281)
Updating files:  48% (135/281)
Updating files:  49% (138/281)
Updating files:  49% (140/281)
Updating files:  50% (141/281)
Updating files:  51% (144/281)
Updating files:  52% (147/281)
Updating files:  53% (149/281)
Updating files:  54% (152/281)
Updating files:  55% (155/281)
Updating files:  56% (158/281)
Updating files:  57% (161/281)
Updating files:  58% (163/281)
Updating files:  59% (166/281)
Updating files:  60% (169/281)
Updating files:  61% (172/281)
Updating files:  62% (175/281)
Updating files:  63% (178/281)
Updating files:  64% (180/281)
Updating files:  65% (183/281)
Updating files:  66% (186/281)
Updating files:  67% (189/281)
Updating files:  68% (192/281)
Updating files:  69% (194/281)
Updating files:  70% (197/281)
Updating files:  71% (200/281)
Updating files:  72% (203/281)
Updating files:  73% (206/281)
Updating files:  74% (208/281)
Updating files:  75% (211/281)
Updating files:  76% (214/281)
Updating files:  77% (217/281)
Updating files:  78% (220/281)
Updating files:  79% (222/281)
Updating files:  80% (225/281)
Updating files:  81% (228/281)
Updating files:  82% (231/281)
Updating files:  83% (234/281)
Updating files:  83% (236/281)
Updating files:  84% (237/281)
Updating files:  85% (239/281)
Updating files:  86% (242/281)
Updating files:  87% (245/281)
Updating files:  88% (248/281)
Updating files:  89% (251/281)
Updating files:  90% (253/281)
Updating files:  91% (256/281)
Updating files:  92% (259/281)
Updating files:  93% (262/281)
Updating files:  94% (265/281)
Updating files:  95% (267/281)
Updating files:  96% (270/281)
Updating files:  97% (273/281)
Updating files:  98% (276/281)
Updating files:  99% (279/281)
Updating files: 100% (281/281)
Updating files: 100% (281/281), done.
[INFO] started tweaking git repo https://github.com/kamui-fin/xines
[INFO] finished tweaking git repo https://github.com/kamui-fin/xines
[INFO] tweaked toml for git repo https://github.com/kamui-fin/xines written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/kamui-fin/xines on toolchain c8a31b780d5415358566a20b94912620a3f27067
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c8a31b780d5415358566a20b94912620a3f27067" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/kamui-fin/xines 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" "+c8a31b780d5415358566a20b94912620a3f27067" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded simplelog v0.12.2
[INFO] [stderr]   Downloaded sdl2 v0.37.0
[INFO] [stderr]   Downloaded sdl2-sys v0.37.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+c8a31b780d5415358566a20b94912620a3f27067" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 78069f5d8b643c22d06faa57aaaee0a84db960c7a0a551b0af4361c158f72b22
[INFO] running `Command { std: "docker" "start" "-a" "78069f5d8b643c22d06faa57aaaee0a84db960c7a0a551b0af4361c158f72b22", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "78069f5d8b643c22d06faa57aaaee0a84db960c7a0a551b0af4361c158f72b22", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "78069f5d8b643c22d06faa57aaaee0a84db960c7a0a551b0af4361c158f72b22", kill_on_drop: false }`
[INFO] [stdout] 78069f5d8b643c22d06faa57aaaee0a84db960c7a0a551b0af4361c158f72b22
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+c8a31b780d5415358566a20b94912620a3f27067" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2a315872d5fe101ddd9c9341238e34a1b045309eba3143e1f0d4242f6d90b8ee
[INFO] running `Command { std: "docker" "start" "-a" "2a315872d5fe101ddd9c9341238e34a1b045309eba3143e1f0d4242f6d90b8ee", kill_on_drop: false }`
[INFO] [stderr]    Compiling sdl2-sys v0.37.0
[INFO] [stderr]    Compiling syn v2.0.72
[INFO] [stderr]    Compiling serde v1.0.204
[INFO] [stderr]    Compiling anyhow v1.0.86
[INFO] [stderr]    Compiling time-macros v0.2.18
[INFO] [stderr]    Compiling wasm-bindgen v0.2.93
[INFO] [stderr]    Compiling serde_json v1.0.122
[INFO] [stderr]    Compiling sdl2 v0.37.0
[INFO] [stderr]     Checking clap_builder v4.5.15
[INFO] [stderr]     Checking time v0.3.36
[INFO] [stderr]     Checking simplelog v0.12.2
[INFO] [stderr]    Compiling wasm-bindgen-backend v0.2.93
[INFO] [stderr]    Compiling serde_derive v1.0.204
[INFO] [stderr]    Compiling clap_derive v4.5.13
[INFO] [stderr]    Compiling wasm-bindgen-macro-support v0.2.93
[INFO] [stderr]    Compiling wasm-bindgen-macro v0.2.93
[INFO] [stderr]     Checking clap v4.5.15
[INFO] [stderr]     Checking nemsys v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Receiver` and `Sender`
[INFO] [stdout]  --> src/cpu/mod.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 |     sync::mpsc::{Receiver, Sender},
[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: `error`
[INFO] [stdout]  --> src/cpu/mod.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | use log::{error, info};
[INFO] [stdout]   |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `memory::MemoryAccessLog`
[INFO] [stdout]  --> src/cpu/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use memory::MemoryAccessLog;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow::Result`
[INFO] [stdout]  --> src/cpu/memory.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::Result;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/cpu/memory.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ppu::memory::VRAM`
[INFO] [stdout]  --> src/cpu/memory.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use ppu::memory::VRAM;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Receiver`, `Sender`, `fs::File`, and `io::Read`
[INFO] [stdout]   --> src/cpu/memory.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout]  7 |     fs::File,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]  8 |     io::Read,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]  9 |     rc::Rc,
[INFO] [stdout] 10 |     sync::mpsc::{Receiver, Sender},
[INFO] [stdout]    |                  ^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `clap::error`
[INFO] [stdout]   --> src/ppu/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use clap::error;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/ppu/mod.rs:267:55
[INFO] [stdout]     |
[INFO] [stdout] 267 |         let mut colors = vec![MASTER_PALETTE[vram.get((0x3F00)) as usize]];
[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] 267 -         let mut colors = vec![MASTER_PALETTE[vram.get((0x3F00)) as usize]];
[INFO] [stdout] 267 +         let mut colors = vec![MASTER_PALETTE[vram.get(0x3F00) as usize]];
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/ppu/mod.rs:269:57
[INFO] [stdout]     |
[INFO] [stdout] 269 |             colors.push(MASTER_PALETTE[min(63, vram.get((self.starting_addr + i)) as usize)]);
[INFO] [stdout]     |                                                         ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 269 -             colors.push(MASTER_PALETTE[min(63, vram.get((self.starting_addr + i)) as usize)]);
[INFO] [stdout] 269 +             colors.push(MASTER_PALETTE[min(63, vram.get(self.starting_addr + i) as usize)]);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `SEC_OAM` should have an upper camel case name
[INFO] [stdout]    --> src/ppu/mod.rs:303:12
[INFO] [stdout]     |
[INFO] [stdout] 303 | pub struct SEC_OAM {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `SecOam`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Receiver` and `Sender`
[INFO] [stdout]  --> src/cpu/mod.rs:4:18
[INFO] [stdout]   |
[INFO] [stdout] 4 |     sync::mpsc::{Receiver, Sender},
[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: `error`
[INFO] [stdout]  --> src/cpu/mod.rs:7:11
[INFO] [stdout]   |
[INFO] [stdout] 7 | use log::{error, info};
[INFO] [stdout]   |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `memory::MemoryAccessLog`
[INFO] [stdout]  --> src/cpu/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use memory::MemoryAccessLog;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `anyhow::Result`
[INFO] [stdout]  --> src/cpu/memory.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::Result;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/cpu/memory.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ppu::memory::VRAM`
[INFO] [stdout]  --> src/cpu/memory.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use ppu::memory::VRAM;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Receiver`, `Sender`, `fs::File`, and `io::Read`
[INFO] [stdout]   --> src/cpu/memory.rs:7:5
[INFO] [stdout]    |
[INFO] [stdout]  7 |     fs::File,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]  8 |     io::Read,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]  9 |     rc::Rc,
[INFO] [stdout] 10 |     sync::mpsc::{Receiver, Sender},
[INFO] [stdout]    |                  ^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `clap::error`
[INFO] [stdout]   --> src/ppu/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use clap::error;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/ppu/mod.rs:267:55
[INFO] [stdout]     |
[INFO] [stdout] 267 |         let mut colors = vec![MASTER_PALETTE[vram.get((0x3F00)) as usize]];
[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] 267 -         let mut colors = vec![MASTER_PALETTE[vram.get((0x3F00)) as usize]];
[INFO] [stdout] 267 +         let mut colors = vec![MASTER_PALETTE[vram.get(0x3F00) as usize]];
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]    --> src/ppu/mod.rs:269:57
[INFO] [stdout]     |
[INFO] [stdout] 269 |             colors.push(MASTER_PALETTE[min(63, vram.get((self.starting_addr + i)) as usize)]);
[INFO] [stdout]     |                                                         ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 269 -             colors.push(MASTER_PALETTE[min(63, vram.get((self.starting_addr + i)) as usize)]);
[INFO] [stdout] 269 +             colors.push(MASTER_PALETTE[min(63, vram.get(self.starting_addr + i) as usize)]);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `SEC_OAM` should have an upper camel case name
[INFO] [stdout]    --> src/ppu/mod.rs:303:12
[INFO] [stdout]     |
[INFO] [stdout] 303 | pub struct SEC_OAM {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `SecOam`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mem_range`
[INFO] [stdout]    --> src/ppu/mod.rs:104:13
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let mem_range = match ptype {
[INFO] [stdout]     |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_mem_range`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `curr_tile_row`
[INFO] [stdout]    --> src/ppu/mod.rs:667:9
[INFO] [stdout]     |
[INFO] [stdout] 667 |         curr_tile_row: usize,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_curr_tile_row`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/ppu/mod.rs:814:17
[INFO] [stdout]     |
[INFO] [stdout] 814 |             let x = self.secondary_oam.sprite_info[i * 4 + 3];
[INFO] [stdout]     |                 ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nt_arrangement` is never read
[INFO] [stdout]   --> src/mappers.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct NROM {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 18 |     nt_arrangement: NametableArrangement,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `native_codes` and `rgbs` are never read
[INFO] [stdout]   --> src/ppu/mod.rs:92:5
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub struct NesColor {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 92 |     native_codes: u8,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 93 |     rgbs: RGB,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `table_2d` and `attr` are never read
[INFO] [stdout]    --> src/ppu/mod.rs:129:5
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub struct Nametable {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 129 |     table_2d: Vec<Vec<u8>>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 130 |     attr: Vec<Vec<u8>>,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `palette_index` is never read
[INFO] [stdout]    --> src/ppu/mod.rs:226:5
[INFO] [stdout]     |
[INFO] [stdout] 208 | pub struct Palette {
[INFO] [stdout]     |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 226 |     palette_index: PaletteIndex,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `horizontal_flip`, `vertical_flip`, `priority`, `lo_byte`, and `hi_byte` are never read
[INFO] [stdout]    --> src/ppu/mod.rs:316:5
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub struct Sprite {
[INFO] [stdout]     |            ------ fields in this struct
[INFO] [stdout] 316 |     horizontal_flip: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 317 |     vertical_flip: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 318 |     priority: bool,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 319 |     lo_byte: u8,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 320 |     hi_byte: u8,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `fine_x` is never read
[INFO] [stdout]    --> src/ppu/mod.rs:358:5
[INFO] [stdout]     |
[INFO] [stdout] 341 | pub struct PPU {
[INFO] [stdout]     |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 358 |     fine_x: u16, // The fine-x position of the current scroll, used during rendering alongside v.
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `mem_range`
[INFO] [stdout]    --> src/ppu/mod.rs:104:13
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let mem_range = match ptype {
[INFO] [stdout]     |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_mem_range`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `default`
[INFO] [stdout]  --> src/bin/test_ppu.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::{default, process};
[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: `error`
[INFO] [stdout]  --> src/bin/test_ppu.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{error, LevelFilter};
[INFO] [stdout]   |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WindowContext`
[INFO] [stdout]  --> src/bin/test_ppu.rs:7:27
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdl2::video::{Window, WindowContext};
[INFO] [stdout]   |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> src/bin/test_ppu.rs:10:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | use nemsys::ppu::{self, PPU};
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PixelFormat`
[INFO] [stdout]   --> src/bin/test_ppu.rs:13:27
[INFO] [stdout]    |
[INFO] [stdout] 13 | use sdl2::pixels::{Color, PixelFormat};
[INFO] [stdout]    |                           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WindowCanvas`
[INFO] [stdout]   --> src/bin/test_ppu.rs:15:37
[INFO] [stdout]    |
[INFO] [stdout] 15 | use sdl2::render::{Canvas, Texture, WindowCanvas};
[INFO] [stdout]    |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::sleep`
[INFO] [stdout]   --> src/bin/test_ppu.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::thread::sleep;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]   --> src/bin/test_ppu.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::time::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `curr_tile_row`
[INFO] [stdout]    --> src/ppu/mod.rs:667:9
[INFO] [stdout]     |
[INFO] [stdout] 667 |         curr_tile_row: usize,
[INFO] [stdout]     |         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_curr_tile_row`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `x`
[INFO] [stdout]    --> src/ppu/mod.rs:814:17
[INFO] [stdout]     |
[INFO] [stdout] 814 |             let x = self.secondary_oam.sprite_info[i * 4 + 3];
[INFO] [stdout]     |                 ^ help: if this is intentional, prefix it with an underscore: `_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nt_arrangement` is never read
[INFO] [stdout]   --> src/mappers.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct NROM {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 18 |     nt_arrangement: NametableArrangement,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `native_codes` and `rgbs` are never read
[INFO] [stdout]   --> src/ppu/mod.rs:92:5
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub struct NesColor {
[INFO] [stdout]    |            -------- fields in this struct
[INFO] [stdout] 92 |     native_codes: u8,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 93 |     rgbs: RGB,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `table_2d` and `attr` are never read
[INFO] [stdout]    --> src/ppu/mod.rs:129:5
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub struct Nametable {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 129 |     table_2d: Vec<Vec<u8>>,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 130 |     attr: Vec<Vec<u8>>,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `palette_index` is never read
[INFO] [stdout]    --> src/ppu/mod.rs:226:5
[INFO] [stdout]     |
[INFO] [stdout] 208 | pub struct Palette {
[INFO] [stdout]     |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 226 |     palette_index: PaletteIndex,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `horizontal_flip`, `vertical_flip`, `priority`, `lo_byte`, and `hi_byte` are never read
[INFO] [stdout]    --> src/ppu/mod.rs:316:5
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub struct Sprite {
[INFO] [stdout]     |            ------ fields in this struct
[INFO] [stdout] 316 |     horizontal_flip: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 317 |     vertical_flip: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 318 |     priority: bool,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 319 |     lo_byte: u8,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 320 |     hi_byte: u8,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `fine_x` is never read
[INFO] [stdout]    --> src/ppu/mod.rs:358:5
[INFO] [stdout]     |
[INFO] [stdout] 341 | pub struct PPU {
[INFO] [stdout]     |            --- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 358 |     fine_x: u16, // The fine-x position of the current scroll, used during rendering alongside v.
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rom`
[INFO] [stdout]    --> src/bin/test_ppu.rs:164:13
[INFO] [stdout]     |
[INFO] [stdout] 164 |         let rom = NROM::from_ines_rom(
[INFO] [stdout]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_rom`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `BLACK` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | static BLACK: Color = Color::RGB(0, 0, 0);
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `WHITE` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | static WHITE: Color = Color::RGB(255, 255, 255);
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `WIDTH` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:36:8
[INFO] [stdout]    |
[INFO] [stdout] 36 | static WIDTH: usize = 256;
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `HEIGHT` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | static HEIGHT: usize = 240;
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `height` and `tex_creator` are never read
[INFO] [stdout]   --> src/bin/test_ppu.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct Display {
[INFO] [stdout]    |        ------- fields in this struct
[INFO] [stdout] 40 |     pub width: u32,
[INFO] [stdout] 41 |     pub height: u32,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub tex_creator: sdl2::render::TextureCreator<sdl2::video::WindowContext>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `draw_grid_over_texture` and `display_pattern_table` are never used
[INFO] [stdout]    --> src/bin/test_ppu.rs:117:8
[INFO] [stdout]     |
[INFO] [stdout]  49 | impl Display {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 117 |     fn draw_grid_over_texture(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 237 |     pub fn display_pattern_table(&mut self, ppu: Rc<RefCell<PPU>>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `default`
[INFO] [stdout]  --> src/bin/test_ppu.rs:3:11
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::{default, process};
[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: `error`
[INFO] [stdout]  --> src/bin/test_ppu.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::{error, LevelFilter};
[INFO] [stdout]   |           ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WindowContext`
[INFO] [stdout]  --> src/bin/test_ppu.rs:7:27
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sdl2::video::{Window, WindowContext};
[INFO] [stdout]   |                           ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]   --> src/bin/test_ppu.rs:10:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | use nemsys::ppu::{self, PPU};
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PixelFormat`
[INFO] [stdout]   --> src/bin/test_ppu.rs:13:27
[INFO] [stdout]    |
[INFO] [stdout] 13 | use sdl2::pixels::{Color, PixelFormat};
[INFO] [stdout]    |                           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `WindowCanvas`
[INFO] [stdout]   --> src/bin/test_ppu.rs:15:37
[INFO] [stdout]    |
[INFO] [stdout] 15 | use sdl2::render::{Canvas, Texture, WindowCanvas};
[INFO] [stdout]    |                                     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::sleep`
[INFO] [stdout]   --> src/bin/test_ppu.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::thread::sleep;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Duration`
[INFO] [stdout]   --> src/bin/test_ppu.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::time::Duration;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rom`
[INFO] [stdout]    --> src/bin/test_ppu.rs:164:13
[INFO] [stdout]     |
[INFO] [stdout] 164 |         let rom = NROM::from_ines_rom(
[INFO] [stdout]     |             ^^^ help: if this is intentional, prefix it with an underscore: `_rom`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `BLACK` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | static BLACK: Color = Color::RGB(0, 0, 0);
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `WHITE` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | static WHITE: Color = Color::RGB(255, 255, 255);
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `WIDTH` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:36:8
[INFO] [stdout]    |
[INFO] [stdout] 36 | static WIDTH: usize = 256;
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `HEIGHT` is never used
[INFO] [stdout]   --> src/bin/test_ppu.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | static HEIGHT: usize = 240;
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `height` and `tex_creator` are never read
[INFO] [stdout]   --> src/bin/test_ppu.rs:41:9
[INFO] [stdout]    |
[INFO] [stdout] 39 | struct Display {
[INFO] [stdout]    |        ------- fields in this struct
[INFO] [stdout] 40 |     pub width: u32,
[INFO] [stdout] 41 |     pub height: u32,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub tex_creator: sdl2::render::TextureCreator<sdl2::video::WindowContext>,
[INFO] [stdout]    |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `draw_grid_over_texture` and `display_pattern_table` are never used
[INFO] [stdout]    --> src/bin/test_ppu.rs:117:8
[INFO] [stdout]     |
[INFO] [stdout]  49 | impl Display {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 117 |     fn draw_grid_over_texture(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 237 |     pub fn display_pattern_table(&mut self, ppu: Rc<RefCell<PPU>>) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 25.44s
[INFO] running `Command { std: "docker" "inspect" "2a315872d5fe101ddd9c9341238e34a1b045309eba3143e1f0d4242f6d90b8ee", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2a315872d5fe101ddd9c9341238e34a1b045309eba3143e1f0d4242f6d90b8ee", kill_on_drop: false }`
[INFO] [stdout] 2a315872d5fe101ddd9c9341238e34a1b045309eba3143e1f0d4242f6d90b8ee
