[INFO] updating cached repository stianeklund/NES [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/stianeklund/NES [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/stianeklund/NES" "work/ex/pr-62849/sources/master#435236b8877cdb98c82eaebfb7887782277265c5/gh/stianeklund/NES"` [INFO] [stderr] Cloning into 'work/ex/pr-62849/sources/master#435236b8877cdb98c82eaebfb7887782277265c5/gh/stianeklund/NES'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/stianeklund/NES" "work/ex/pr-62849/sources/try#b5c7f157c20453dde8d47371abe73b32351b4e7f/gh/stianeklund/NES"` [INFO] [stderr] Cloning into 'work/ex/pr-62849/sources/try#b5c7f157c20453dde8d47371abe73b32351b4e7f/gh/stianeklund/NES'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] c8f1a01814b86eacd30140f42e5d70229dd97ffb [INFO] sha for GitHub repo stianeklund/NES: c8f1a01814b86eacd30140f42e5d70229dd97ffb [INFO] validating manifest of stianeklund/NES on toolchain master#435236b8877cdb98c82eaebfb7887782277265c5 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+435236b8877cdb98c82eaebfb7887782277265c5-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of stianeklund/NES on toolchain try#b5c7f157c20453dde8d47371abe73b32351b4e7f [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+b5c7f157c20453dde8d47371abe73b32351b4e7f-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing stianeklund/NES [INFO] finished frobbing stianeklund/NES [INFO] frobbed toml for stianeklund/NES written to work/ex/pr-62849/sources/master#435236b8877cdb98c82eaebfb7887782277265c5/gh/stianeklund/NES/Cargo.toml [INFO] started frobbing stianeklund/NES [INFO] finished frobbing stianeklund/NES [INFO] frobbed toml for stianeklund/NES written to work/ex/pr-62849/sources/try#b5c7f157c20453dde8d47371abe73b32351b4e7f/gh/stianeklund/NES/Cargo.toml [INFO] crate stianeklund/NES already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+435236b8877cdb98c82eaebfb7887782277265c5-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+b5c7f157c20453dde8d47371abe73b32351b4e7f-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] checking stianeklund/NES against try#b5c7f157c20453dde8d47371abe73b32351b4e7f for pr-62849 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-62849/worker-1/try#b5c7f157c20453dde8d47371abe73b32351b4e7f:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-62849/sources/try#b5c7f157c20453dde8d47371abe73b32351b4e7f/gh/stianeklund/NES:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+b5c7f157c20453dde8d47371abe73b32351b4e7f-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] 88d510836a566b8a22fd6a9cbe535e9449fc3ece805dfcab8717da557d5ef29c [INFO] running `"docker" "start" "-a" "88d510836a566b8a22fd6a9cbe535e9449fc3ece805dfcab8717da557d5ef29c"` [INFO] [stderr] Compiling minifb v0.10.3 [INFO] [stderr] Checking x11-dl v2.14.0 [INFO] [stderr] Checking nes v0.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: unused imports: `RangeTo`, `Range` [INFO] [stderr] --> src/rom.rs:3:16 [INFO] [stderr] | [INFO] [stderr] 3 | use std::ops::{Range, RangeTo}; [INFO] [stderr] | ^^^^^ ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt` [INFO] [stderr] --> src/rom.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::fmt; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Error` [INFO] [stderr] --> src/rom.rs:8:23 [INFO] [stderr] | [INFO] [stderr] 8 | use std::io::{Result, Error}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `memory::Ram` [INFO] [stderr] --> src/rom.rs:10:5 [INFO] [stderr] | [INFO] [stderr] 10 | use memory::Ram; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Interconnect` [INFO] [stderr] --> src/rom.rs:11:34 [INFO] [stderr] | [INFO] [stderr] 11 | use interconnect::{MemoryMapper, Interconnect}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::convert` [INFO] [stderr] --> src/rom.rs:12:5 [INFO] [stderr] | [INFO] [stderr] 12 | use std::convert; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:81:15 [INFO] [stderr] | [INFO] [stderr] 81 | 0 ... 0x07ff => panic!("Trying to read RAM from Cartridge"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:82:20 [INFO] [stderr] | [INFO] [stderr] 82 | 0x0800 ... 0x1fff => panic!("Trying to read RAM Mirror from Cartridge"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:83:20 [INFO] [stderr] | [INFO] [stderr] 83 | 0x2000 ... 0x3fff => panic!("Trying to read from PPU registers. Not implemented"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:84:20 [INFO] [stderr] | [INFO] [stderr] 84 | 0x8000 ... 0xffff => self.prg[addr as usize & 0x3fff], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:91:15 [INFO] [stderr] | [INFO] [stderr] 91 | 0 ... 0x07ff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:92:20 [INFO] [stderr] | [INFO] [stderr] 92 | 0x0800 ... 0x1fff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:93:20 [INFO] [stderr] | [INFO] [stderr] 93 | 0x2000 ... 0x3fff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:94:20 [INFO] [stderr] | [INFO] [stderr] 94 | 0x8000 ... 0xffff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Cpu`, `ExecutionContext` [INFO] [stderr] --> src/interconnect.rs:2:11 [INFO] [stderr] | [INFO] [stderr] 2 | use cpu::{ExecutionContext, Cpu, Registers}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ppu::Ppu` [INFO] [stderr] --> src/interconnect.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use ppu::Ppu; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:26:14 [INFO] [stderr] | [INFO] [stderr] 26 | 0...0x07ff => "RAM", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:27:19 [INFO] [stderr] | [INFO] [stderr] 27 | 0x0800...0x1fff => "RAM MIRROR", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:35:19 [INFO] [stderr] | [INFO] [stderr] 35 | 0x2008...0x2fff => "PPU VRAM", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:36:19 [INFO] [stderr] | [INFO] [stderr] 36 | 0x3000...0x3eff => "PPU VRAM MIRROR", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:37:19 [INFO] [stderr] | [INFO] [stderr] 37 | 0x3f00...0x3fff => "INTERNAL PALETTE CONTROL", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:38:19 [INFO] [stderr] | [INFO] [stderr] 38 | 0x4000...0x4003 => "APU PULSE 1", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:39:19 [INFO] [stderr] | [INFO] [stderr] 39 | 0x4004...0x4007 => "APU PULSE 2", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:40:19 [INFO] [stderr] | [INFO] [stderr] 40 | 0x4008...0x400b => "APU TRIANGLE", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:41:19 [INFO] [stderr] | [INFO] [stderr] 41 | 0x400c...0x400f => "APU NOISE", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:42:19 [INFO] [stderr] | [INFO] [stderr] 42 | 0x4010...0x4013 => "APU DMC", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:45:19 [INFO] [stderr] | [INFO] [stderr] 45 | 0x6000...0x7fff => "SRAM", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:46:19 [INFO] [stderr] | [INFO] [stderr] 46 | 0x8000...0xffff => "CART", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unused import: `StatusRegister` [INFO] [stderr] --> src/opcode.rs:2:11 [INFO] [stderr] | [INFO] [stderr] 2 | use cpu::{StatusRegister}; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `UpperHex` [INFO] [stderr] --> src/memory.rs:2:16 [INFO] [stderr] | [INFO] [stderr] 2 | use std::fmt::{UpperHex, LowerHex}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::path::Path` [INFO] [stderr] --> src/memory.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::path::Path; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fs::File` [INFO] [stderr] --> src/memory.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::fs::File; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io::Read` [INFO] [stderr] --> src/memory.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::io::Read; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Cartridge`, `RomHeader` [INFO] [stderr] --> src/memory.rs:7:11 [INFO] [stderr] | [INFO] [stderr] 7 | use rom::{Cartridge, RomHeader}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `FrameBuffer` [INFO] [stderr] --> src/cpu.rs:5:16 [INFO] [stderr] | [INFO] [stderr] 5 | use ppu::{Ppu, FrameBuffer}; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:14:14 [INFO] [stderr] | [INFO] [stderr] 14 | 0...0x07ff => self.ram.memory[addr as usize] as u8, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:15:20 [INFO] [stderr] | [INFO] [stderr] 15 | 0x0800 ... 0x1fff => self.ram.memory[addr as usize & 0x07ff], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:16:20 [INFO] [stderr] | [INFO] [stderr] 16 | 0x2000 ... 0x3fff => self.ppu.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:17:20 [INFO] [stderr] | [INFO] [stderr] 17 | 0x4000 ... 0x4017 => self.apu.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:18:20 [INFO] [stderr] | [INFO] [stderr] 18 | 0x4018 ... 0x401f => unimplemented!("Read to CPU Test space"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:20:20 [INFO] [stderr] | [INFO] [stderr] 20 | 0x6000 ... 0x7fff => self.ram.sram[addr as usize] as u8, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:21:19 [INFO] [stderr] | [INFO] [stderr] 21 | 0x8000...0xffff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:35:14 [INFO] [stderr] | [INFO] [stderr] 35 | 0...0x07ff => self.ram.memory[addr as usize] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:36:19 [INFO] [stderr] | [INFO] [stderr] 36 | 0x0800...0x1fff => self.ram.memory[addr as usize & 0x07ff] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:43:20 [INFO] [stderr] | [INFO] [stderr] 43 | 0x2000 ... 0x3fff => self.ppu.write(addr,byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:44:20 [INFO] [stderr] | [INFO] [stderr] 44 | 0x4000 ... 0x4017 => self.apu.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:45:20 [INFO] [stderr] | [INFO] [stderr] 45 | 0x6000 ... 0x7fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:53:19 [INFO] [stderr] | [INFO] [stderr] 53 | 0x8000...0xffff => self.cart.prg[addr as usize & 0x3fff] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/cpu.rs:220:25 [INFO] [stderr] | [INFO] [stderr] 220 | let data: u16 = (self.read(imm) as u16); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `Interconnect` [INFO] [stderr] --> src/ppu.rs:1:34 [INFO] [stderr] | [INFO] [stderr] 1 | use interconnect::{MemoryMapper, Interconnect}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Scale` [INFO] [stderr] --> src/ppu.rs:2:14 [INFO] [stderr] | [INFO] [stderr] 2 | use minifb::{Scale, WindowOptions, Window}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:152:14 [INFO] [stderr] | [INFO] [stderr] 152 | 0... 0x1fff => self.chr[addr as usize], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:161:20 [INFO] [stderr] | [INFO] [stderr] 161 | 0x2008 ... 0x2fff => self.vram[addr as usize], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:162:20 [INFO] [stderr] | [INFO] [stderr] 162 | 0x3000 ... 0x3eff => self.vram[addr as usize & 0x2eff], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:163:20 [INFO] [stderr] | [INFO] [stderr] 163 | 0x3f00 ... 0x3fff => panic!("Internal palette control; not implemented"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:169:14 [INFO] [stderr] | [INFO] [stderr] 169 | 0... 0x1fff => self.chr[addr as usize] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:180:20 [INFO] [stderr] | [INFO] [stderr] 180 | 0x2008 ... 0x2fff => self.vram[addr as usize] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:182:20 [INFO] [stderr] | [INFO] [stderr] 182 | 0x3000 ... 0x3eff => self.vram[addr as usize & 0x2eff] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:183:20 [INFO] [stderr] | [INFO] [stderr] 183 | 0x3f00 ... 0x3fff => panic!("Internal palette control; not implemented"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:32:20 [INFO] [stderr] | [INFO] [stderr] 32 | 0x4000 ... 0x4003 => self.reg.pulse_1, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:33:20 [INFO] [stderr] | [INFO] [stderr] 33 | 0x4004 ... 0x4007 => self.reg.pulse_2, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:34:20 [INFO] [stderr] | [INFO] [stderr] 34 | 0x4008 ... 0x400b => self.reg.triangle, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:35:20 [INFO] [stderr] | [INFO] [stderr] 35 | 0x400c ... 0x400f => self.reg.noise, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:36:20 [INFO] [stderr] | [INFO] [stderr] 36 | 0x4010 ... 0x4013 => self.reg.dmc, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:46:20 [INFO] [stderr] | [INFO] [stderr] 46 | 0x4000 ... 0x4003 => self.reg.pulse_1 = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:47:20 [INFO] [stderr] | [INFO] [stderr] 47 | 0x4004 ... 0x4007 => self.reg.pulse_2 = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | 0x4008 ... 0x400b => self.reg.triangle = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:49:20 [INFO] [stderr] | [INFO] [stderr] 49 | 0x400c ... 0x400f => self.reg.noise = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:50:20 [INFO] [stderr] | [INFO] [stderr] 50 | 0x4010 ... 0x4013 => self.reg.dmc = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Read`, `self` [INFO] [stderr] --> src/main.rs:14:15 [INFO] [stderr] | [INFO] [stderr] 14 | use std::io::{self, Read}; [INFO] [stderr] | ^^^^ ^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Interconnect` [INFO] [stderr] --> src/main.rs:16:20 [INFO] [stderr] | [INFO] [stderr] 16 | use interconnect::{Interconnect, MemoryMapper}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `RangeTo`, `Range` [INFO] [stderr] --> src/rom.rs:3:16 [INFO] [stderr] | [INFO] [stderr] 3 | use std::ops::{Range, RangeTo}; [INFO] [stderr] | ^^^^^ ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fmt` [INFO] [stderr] --> src/rom.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::fmt; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Error` [INFO] [stderr] --> src/rom.rs:8:23 [INFO] [stderr] | [INFO] [stderr] 8 | use std::io::{Result, Error}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `memory::Ram` [INFO] [stderr] --> src/rom.rs:10:5 [INFO] [stderr] | [INFO] [stderr] 10 | use memory::Ram; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Interconnect` [INFO] [stderr] --> src/rom.rs:11:34 [INFO] [stderr] | [INFO] [stderr] 11 | use interconnect::{MemoryMapper, Interconnect}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::convert` [INFO] [stderr] --> src/rom.rs:12:5 [INFO] [stderr] | [INFO] [stderr] 12 | use std::convert; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:81:15 [INFO] [stderr] | [INFO] [stderr] 81 | 0 ... 0x07ff => panic!("Trying to read RAM from Cartridge"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:82:20 [INFO] [stderr] | [INFO] [stderr] 82 | 0x0800 ... 0x1fff => panic!("Trying to read RAM Mirror from Cartridge"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:83:20 [INFO] [stderr] | [INFO] [stderr] 83 | 0x2000 ... 0x3fff => panic!("Trying to read from PPU registers. Not implemented"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:84:20 [INFO] [stderr] | [INFO] [stderr] 84 | 0x8000 ... 0xffff => self.prg[addr as usize & 0x3fff], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:91:15 [INFO] [stderr] | [INFO] [stderr] 91 | 0 ... 0x07ff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:92:20 [INFO] [stderr] | [INFO] [stderr] 92 | 0x0800 ... 0x1fff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:93:20 [INFO] [stderr] | [INFO] [stderr] 93 | 0x2000 ... 0x3fff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/rom.rs:94:20 [INFO] [stderr] | [INFO] [stderr] 94 | 0x8000 ... 0xffff => self.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Cpu`, `ExecutionContext` [INFO] [stderr] --> src/interconnect.rs:2:11 [INFO] [stderr] | [INFO] [stderr] 2 | use cpu::{ExecutionContext, Cpu, Registers}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^ ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `ppu::Ppu` [INFO] [stderr] --> src/interconnect.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use ppu::Ppu; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:26:14 [INFO] [stderr] | [INFO] [stderr] 26 | 0...0x07ff => "RAM", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:27:19 [INFO] [stderr] | [INFO] [stderr] 27 | 0x0800...0x1fff => "RAM MIRROR", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:35:19 [INFO] [stderr] | [INFO] [stderr] 35 | 0x2008...0x2fff => "PPU VRAM", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:36:19 [INFO] [stderr] | [INFO] [stderr] 36 | 0x3000...0x3eff => "PPU VRAM MIRROR", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:37:19 [INFO] [stderr] | [INFO] [stderr] 37 | 0x3f00...0x3fff => "INTERNAL PALETTE CONTROL", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:38:19 [INFO] [stderr] | [INFO] [stderr] 38 | 0x4000...0x4003 => "APU PULSE 1", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:39:19 [INFO] [stderr] | [INFO] [stderr] 39 | 0x4004...0x4007 => "APU PULSE 2", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:40:19 [INFO] [stderr] | [INFO] [stderr] 40 | 0x4008...0x400b => "APU TRIANGLE", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:41:19 [INFO] [stderr] | [INFO] [stderr] 41 | 0x400c...0x400f => "APU NOISE", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:42:19 [INFO] [stderr] | [INFO] [stderr] 42 | 0x4010...0x4013 => "APU DMC", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:45:19 [INFO] [stderr] | [INFO] [stderr] 45 | 0x6000...0x7fff => "SRAM", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/interconnect.rs:46:19 [INFO] [stderr] | [INFO] [stderr] 46 | 0x8000...0xffff => "CART", [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unused import: `StatusRegister` [INFO] [stderr] --> src/opcode.rs:2:11 [INFO] [stderr] | [INFO] [stderr] 2 | use cpu::{StatusRegister}; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `UpperHex` [INFO] [stderr] --> src/memory.rs:2:16 [INFO] [stderr] | [INFO] [stderr] 2 | use std::fmt::{UpperHex, LowerHex}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::path::Path` [INFO] [stderr] --> src/memory.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::path::Path; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fs::File` [INFO] [stderr] --> src/memory.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::fs::File; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io::Read` [INFO] [stderr] --> src/memory.rs:6:5 [INFO] [stderr] | [INFO] [stderr] 6 | use std::io::Read; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Cartridge`, `RomHeader` [INFO] [stderr] --> src/memory.rs:7:11 [INFO] [stderr] | [INFO] [stderr] 7 | use rom::{Cartridge, RomHeader}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `FrameBuffer` [INFO] [stderr] --> src/cpu.rs:5:16 [INFO] [stderr] | [INFO] [stderr] 5 | use ppu::{Ppu, FrameBuffer}; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:14:14 [INFO] [stderr] | [INFO] [stderr] 14 | 0...0x07ff => self.ram.memory[addr as usize] as u8, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:15:20 [INFO] [stderr] | [INFO] [stderr] 15 | 0x0800 ... 0x1fff => self.ram.memory[addr as usize & 0x07ff], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:16:20 [INFO] [stderr] | [INFO] [stderr] 16 | 0x2000 ... 0x3fff => self.ppu.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:17:20 [INFO] [stderr] | [INFO] [stderr] 17 | 0x4000 ... 0x4017 => self.apu.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:18:20 [INFO] [stderr] | [INFO] [stderr] 18 | 0x4018 ... 0x401f => unimplemented!("Read to CPU Test space"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:20:20 [INFO] [stderr] | [INFO] [stderr] 20 | 0x6000 ... 0x7fff => self.ram.sram[addr as usize] as u8, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:21:19 [INFO] [stderr] | [INFO] [stderr] 21 | 0x8000...0xffff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:35:14 [INFO] [stderr] | [INFO] [stderr] 35 | 0...0x07ff => self.ram.memory[addr as usize] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:36:19 [INFO] [stderr] | [INFO] [stderr] 36 | 0x0800...0x1fff => self.ram.memory[addr as usize & 0x07ff] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:43:20 [INFO] [stderr] | [INFO] [stderr] 43 | 0x2000 ... 0x3fff => self.ppu.write(addr,byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:44:20 [INFO] [stderr] | [INFO] [stderr] 44 | 0x4000 ... 0x4017 => self.apu.write(addr, byte), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:45:20 [INFO] [stderr] | [INFO] [stderr] 45 | 0x6000 ... 0x7fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:53:19 [INFO] [stderr] | [INFO] [stderr] 53 | 0x8000...0xffff => self.cart.prg[addr as usize & 0x3fff] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around assigned value [INFO] [stderr] --> src/cpu.rs:220:25 [INFO] [stderr] | [INFO] [stderr] 220 | let data: u16 = (self.read(imm) as u16); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `Interconnect` [INFO] [stderr] --> src/ppu.rs:1:34 [INFO] [stderr] | [INFO] [stderr] 1 | use interconnect::{MemoryMapper, Interconnect}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Scale` [INFO] [stderr] --> src/ppu.rs:2:14 [INFO] [stderr] | [INFO] [stderr] 2 | use minifb::{Scale, WindowOptions, Window}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:152:14 [INFO] [stderr] | [INFO] [stderr] 152 | 0... 0x1fff => self.chr[addr as usize], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:161:20 [INFO] [stderr] | [INFO] [stderr] 161 | 0x2008 ... 0x2fff => self.vram[addr as usize], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:162:20 [INFO] [stderr] | [INFO] [stderr] 162 | 0x3000 ... 0x3eff => self.vram[addr as usize & 0x2eff], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:163:20 [INFO] [stderr] | [INFO] [stderr] 163 | 0x3f00 ... 0x3fff => panic!("Internal palette control; not implemented"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:169:14 [INFO] [stderr] | [INFO] [stderr] 169 | 0... 0x1fff => self.chr[addr as usize] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:180:20 [INFO] [stderr] | [INFO] [stderr] 180 | 0x2008 ... 0x2fff => self.vram[addr as usize] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:182:20 [INFO] [stderr] | [INFO] [stderr] 182 | 0x3000 ... 0x3eff => self.vram[addr as usize & 0x2eff] = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/ppu.rs:183:20 [INFO] [stderr] | [INFO] [stderr] 183 | 0x3f00 ... 0x3fff => panic!("Internal palette control; not implemented"), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:32:20 [INFO] [stderr] | [INFO] [stderr] 32 | 0x4000 ... 0x4003 => self.reg.pulse_1, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:33:20 [INFO] [stderr] | [INFO] [stderr] 33 | 0x4004 ... 0x4007 => self.reg.pulse_2, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:34:20 [INFO] [stderr] | [INFO] [stderr] 34 | 0x4008 ... 0x400b => self.reg.triangle, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:35:20 [INFO] [stderr] | [INFO] [stderr] 35 | 0x400c ... 0x400f => self.reg.noise, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:36:20 [INFO] [stderr] | [INFO] [stderr] 36 | 0x4010 ... 0x4013 => self.reg.dmc, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:46:20 [INFO] [stderr] | [INFO] [stderr] 46 | 0x4000 ... 0x4003 => self.reg.pulse_1 = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:47:20 [INFO] [stderr] | [INFO] [stderr] 47 | 0x4004 ... 0x4007 => self.reg.pulse_2 = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | 0x4008 ... 0x400b => self.reg.triangle = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:49:20 [INFO] [stderr] | [INFO] [stderr] 49 | 0x400c ... 0x400f => self.reg.noise = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/apu.rs:50:20 [INFO] [stderr] | [INFO] [stderr] 50 | 0x4010 ... 0x4013 => self.reg.dmc = byte, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Read`, `self` [INFO] [stderr] --> src/main.rs:14:15 [INFO] [stderr] | [INFO] [stderr] 14 | use std::io::{self, Read}; [INFO] [stderr] | ^^^^ ^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Interconnect` [INFO] [stderr] --> src/main.rs:16:20 [INFO] [stderr] | [INFO] [stderr] 16 | use interconnect::{Interconnect, MemoryMapper}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: value assigned to `prg_lenght` is never read [INFO] [stderr] --> src/rom.rs:196:17 [INFO] [stderr] | [INFO] [stderr] 196 | let mut prg_lenght = 0; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_assignments)]` on by default [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: value assigned to `mask_amount` is never read [INFO] [stderr] --> src/cpu.rs:22:25 [INFO] [stderr] | [INFO] [stderr] 22 | let mut mask_amount = 0; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: unused variable: `value` [INFO] [stderr] --> src/cpu.rs:715:23 [INFO] [stderr] | [INFO] [stderr] 715 | fn rti(&mut self, value: u16) { [INFO] [stderr] | ^^^^^ help: consider prefixing with an underscore: `_value` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: value assigned to `prg_lenght` is never read [INFO] [stderr] --> src/rom.rs:196:17 [INFO] [stderr] | [INFO] [stderr] 196 | let mut prg_lenght = 0; [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_assignments)]` on by default [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: value assigned to `mask_amount` is never read [INFO] [stderr] --> src/cpu.rs:22:25 [INFO] [stderr] | [INFO] [stderr] 22 | let mut mask_amount = 0; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: maybe it is overwritten before being read? [INFO] [stderr] [INFO] [stderr] warning: unused variable: `value` [INFO] [stderr] --> src/cpu.rs:715:23 [INFO] [stderr] | [INFO] [stderr] 715 | fn rti(&mut self, value: u16) { [INFO] [stderr] | ^^^^^ help: consider prefixing with an underscore: `_value` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/cpu.rs:247:13 [INFO] [stderr] | [INFO] [stderr] 247 | let mut m; // store address mode in m variable [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/ppu.rs:39:9 [INFO] [stderr] | [INFO] [stderr] 39 | let mut window = Window::new( [INFO] [stderr] | ----^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: method is never used: `mask_addr` [INFO] [stderr] --> src/rom.rs:124:5 [INFO] [stderr] | [INFO] [stderr] 124 | fn mask_addr(&self, addr: u16) -> u16 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: method is never used: `retrieve_mapper_id` [INFO] [stderr] --> src/rom.rs:130:5 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn retrieve_mapper_id(&self) -> u8 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `read_rom` [INFO] [stderr] --> src/rom.rs:134:5 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn read_rom(&mut self, file: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `AddressMatch` [INFO] [stderr] --> src/interconnect.rs:5:1 [INFO] [stderr] | [INFO] [stderr] 5 | pub struct AddressMatch { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Interconnect` [INFO] [stderr] --> src/interconnect.rs:53:1 [INFO] [stderr] | [INFO] [stderr] 53 | pub struct Interconnect { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `default` [INFO] [stderr] --> src/interconnect.rs:60:5 [INFO] [stderr] | [INFO] [stderr] 60 | pub fn default() -> Box { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `A` [INFO] [stderr] --> src/opcode.rs:22:5 [INFO] [stderr] | [INFO] [stderr] 22 | A, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `X` [INFO] [stderr] --> src/opcode.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | X, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Y` [INFO] [stderr] --> src/opcode.rs:24:5 [INFO] [stderr] | [INFO] [stderr] 24 | Y, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `default` [INFO] [stderr] --> src/opcode.rs:41:5 [INFO] [stderr] | [INFO] [stderr] 41 | pub fn default() -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `default` [INFO] [stderr] --> src/cpu.rs:85:5 [INFO] [stderr] | [INFO] [stderr] 85 | pub fn default() -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `adv_pc` [INFO] [stderr] --> src/cpu.rs:159:5 [INFO] [stderr] | [INFO] [stderr] 159 | fn adv_pc(&mut self, amount: u16) { self.cpu.reg.pc = self.cpu.reg.pc.wrapping_add(amount); } [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `cli` [INFO] [stderr] --> src/cpu.rs:554:5 [INFO] [stderr] | [INFO] [stderr] 554 | fn cli(&mut self) { self.cpu.flags.interrupt = false; } [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `sloa` [INFO] [stderr] --> src/cpu.rs:744:5 [INFO] [stderr] | [INFO] [stderr] 744 | fn sloa(&mut self, value: u16) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `FrameBuffer` [INFO] [stderr] --> src/ppu.rs:33:1 [INFO] [stderr] | [INFO] [stderr] 33 | pub struct FrameBuffer { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `new` [INFO] [stderr] --> src/ppu.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | pub fn new() -> FrameBuffer { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `PpuDataBus` [INFO] [stderr] --> src/ppu.rs:108:1 [INFO] [stderr] | [INFO] [stderr] 108 | pub struct PpuDataBus { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never used: `status` [INFO] [stderr] --> src/apu.rs:22:5 [INFO] [stderr] | [INFO] [stderr] 22 | status: u8, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error: literal out of range for `u8` [INFO] [stderr] --> src/rom.rs:56:27 [INFO] [stderr] | [INFO] [stderr] 56 | prg_ram_size: 8192, [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[deny(overflowing_literals)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/ppu.rs:136:9 [INFO] [stderr] | [INFO] [stderr] 136 | / writeln!(f, "{}\t{}\t{}\t{}\t{}\t{}{}", [INFO] [stderr] 137 | | "CTRL","MASK","OAM","DATA","SCROLL","ADDR\t", "DMA\t"); [INFO] [stderr] | |________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: this warning originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: unused return value of `core::num::::wrapping_add` that must be used [INFO] [stderr] --> src/ppu.rs:150:13 [INFO] [stderr] | [INFO] [stderr] 150 | self.cycle.wrapping_add(1); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this returns the result of the operation, without modifying the original [INFO] [stderr] [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/cpu.rs:247:13 [INFO] [stderr] | [INFO] [stderr] 247 | let mut m; // store address mode in m variable [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] error: Could not compile `nes`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/ppu.rs:39:9 [INFO] [stderr] | [INFO] [stderr] 39 | let mut window = Window::new( [INFO] [stderr] | ----^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: method is never used: `mask_addr` [INFO] [stderr] --> src/rom.rs:124:5 [INFO] [stderr] | [INFO] [stderr] 124 | fn mask_addr(&self, addr: u16) -> u16 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: method is never used: `retrieve_mapper_id` [INFO] [stderr] --> src/rom.rs:130:5 [INFO] [stderr] | [INFO] [stderr] 130 | pub fn retrieve_mapper_id(&self) -> u8 { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `read_rom` [INFO] [stderr] --> src/rom.rs:134:5 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn read_rom(&mut self, file: &str) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `AddressMatch` [INFO] [stderr] --> src/interconnect.rs:5:1 [INFO] [stderr] | [INFO] [stderr] 5 | pub struct AddressMatch { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Interconnect` [INFO] [stderr] --> src/interconnect.rs:53:1 [INFO] [stderr] | [INFO] [stderr] 53 | pub struct Interconnect { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `default` [INFO] [stderr] --> src/interconnect.rs:60:5 [INFO] [stderr] | [INFO] [stderr] 60 | pub fn default() -> Box { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `A` [INFO] [stderr] --> src/opcode.rs:22:5 [INFO] [stderr] | [INFO] [stderr] 22 | A, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `X` [INFO] [stderr] --> src/opcode.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | X, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: variant is never constructed: `Y` [INFO] [stderr] --> src/opcode.rs:24:5 [INFO] [stderr] | [INFO] [stderr] 24 | Y, [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `default` [INFO] [stderr] --> src/opcode.rs:41:5 [INFO] [stderr] | [INFO] [stderr] 41 | pub fn default() -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `default` [INFO] [stderr] --> src/cpu.rs:85:5 [INFO] [stderr] | [INFO] [stderr] 85 | pub fn default() -> Self { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `adv_pc` [INFO] [stderr] --> src/cpu.rs:159:5 [INFO] [stderr] | [INFO] [stderr] 159 | fn adv_pc(&mut self, amount: u16) { self.cpu.reg.pc = self.cpu.reg.pc.wrapping_add(amount); } [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `cli` [INFO] [stderr] --> src/cpu.rs:554:5 [INFO] [stderr] | [INFO] [stderr] 554 | fn cli(&mut self) { self.cpu.flags.interrupt = false; } [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `sloa` [INFO] [stderr] --> src/cpu.rs:744:5 [INFO] [stderr] | [INFO] [stderr] 744 | fn sloa(&mut self, value: u16) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `FrameBuffer` [INFO] [stderr] --> src/ppu.rs:33:1 [INFO] [stderr] | [INFO] [stderr] 33 | pub struct FrameBuffer { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `new` [INFO] [stderr] --> src/ppu.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | pub fn new() -> FrameBuffer { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `PpuDataBus` [INFO] [stderr] --> src/ppu.rs:108:1 [INFO] [stderr] | [INFO] [stderr] 108 | pub struct PpuDataBus { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never used: `status` [INFO] [stderr] --> src/apu.rs:22:5 [INFO] [stderr] | [INFO] [stderr] 22 | status: u8, [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error: literal out of range for `u8` [INFO] [stderr] --> src/rom.rs:56:27 [INFO] [stderr] | [INFO] [stderr] 56 | prg_ram_size: 8192, [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[deny(overflowing_literals)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/ppu.rs:136:9 [INFO] [stderr] | [INFO] [stderr] 136 | / writeln!(f, "{}\t{}\t{}\t{}\t{}\t{}{}", [INFO] [stderr] 137 | | "CTRL","MASK","OAM","DATA","SCROLL","ADDR\t", "DMA\t"); [INFO] [stderr] | |________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] = note: this warning originates in a macro outside of the current crate (in Nightly builds, run with -Z external-macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: unused return value of `core::num::::wrapping_add` that must be used [INFO] [stderr] --> src/ppu.rs:150:13 [INFO] [stderr] | [INFO] [stderr] 150 | self.cycle.wrapping_add(1); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this returns the result of the operation, without modifying the original [INFO] [stderr] [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] error: Could not compile `nes`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "88d510836a566b8a22fd6a9cbe535e9449fc3ece805dfcab8717da557d5ef29c"` [INFO] running `"docker" "rm" "-f" "88d510836a566b8a22fd6a9cbe535e9449fc3ece805dfcab8717da557d5ef29c"` [INFO] [stdout] 88d510836a566b8a22fd6a9cbe535e9449fc3ece805dfcab8717da557d5ef29c