[INFO] cloning repository https://github.com/baileyforrest/gbc [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/baileyforrest/gbc" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbaileyforrest%2Fgbc", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbaileyforrest%2Fgbc'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 47b902177d5e3fcfcfb9f9c15c5e1930abca1971 [INFO] checking baileyforrest/gbc against try#8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8 for pr-82565 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fbaileyforrest%2Fgbc" "/workspace/builds/worker-0/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-0/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/baileyforrest/gbc on toolchain 8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/baileyforrest/gbc [INFO] finished tweaking git repo https://github.com/baileyforrest/gbc [INFO] tweaked toml for git repo https://github.com/baileyforrest/gbc written to /workspace/builds/worker-0/source/Cargo.toml [INFO] crate git repo https://github.com/baileyforrest/gbc already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/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" "rustops/crates-build-env@sha256:f2f6bcd4b43ebee4e173f653a26493129bdb64017c85f916b780ca7fbdbaa79d" "/opt/rustwide/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 5553d85ed5a18ce9c168ad8909c0f100e8f74c998849ae30f2cb8397662918e7 [INFO] running `Command { std: "docker" "start" "-a" "5553d85ed5a18ce9c168ad8909c0f100e8f74c998849ae30f2cb8397662918e7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "5553d85ed5a18ce9c168ad8909c0f100e8f74c998849ae30f2cb8397662918e7", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5553d85ed5a18ce9c168ad8909c0f100e8f74c998849ae30f2cb8397662918e7", kill_on_drop: false }` [INFO] [stdout] 5553d85ed5a18ce9c168ad8909c0f100e8f74c998849ae30f2cb8397662918e7 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0/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" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:f2f6bcd4b43ebee4e173f653a26493129bdb64017c85f916b780ca7fbdbaa79d" "/opt/rustwide/cargo-home/bin/cargo" "+8e3afc79c11f48cb3acd1be5b3b7de98fe3f93a8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 502945439c92aaf81b2b2fb991e4e540d9eb8136e71ba12e4a6e7ef5d52332bf [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "502945439c92aaf81b2b2fb991e4e540d9eb8136e71ba12e4a6e7ef5d52332bf", kill_on_drop: false }` [INFO] [stderr] Checking gbc v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/cpu.rs:560:30 [INFO] [stdout] | [INFO] [stdout] 560 | ... 3...7 => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/cpu.rs:829:30 [INFO] [stdout] | [INFO] [stdout] 829 | ... 0...3 => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/cpu.rs:931:30 [INFO] [stdout] | [INFO] [stdout] 931 | ... 0...3 => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/mem.rs:176:24 [INFO] [stdout] | [INFO] [stdout] 176 | fn read_bank(rom: &mut Read) -> Result<[u8; 0x4000], CartErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:189:19 [INFO] [stdout] | [INFO] [stdout] 189 | 0x0000...0x3fff => self.rom[0][addr as usize], [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:190:19 [INFO] [stdout] | [INFO] [stdout] 190 | 0x4000...0x7fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:211:19 [INFO] [stdout] | [INFO] [stdout] 211 | 0xa000...0xbfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:228:19 [INFO] [stdout] | [INFO] [stdout] 228 | 0x0000...0x1fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:231:19 [INFO] [stdout] | [INFO] [stdout] 231 | 0x2000...0x3fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:235:19 [INFO] [stdout] | [INFO] [stdout] 235 | 0x4000...0x5fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:238:19 [INFO] [stdout] | [INFO] [stdout] 238 | 0x6000...0x7fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:241:19 [INFO] [stdout] | [INFO] [stdout] 241 | 0xa000...0xbfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/mem.rs:256:38 [INFO] [stdout] | [INFO] [stdout] 256 | pub fn load(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:264:17 [INFO] [stdout] | [INFO] [stdout] 264 | 0x01...0x03 => self.mbc_type = MbcType::Mbc1, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:265:17 [INFO] [stdout] | [INFO] [stdout] 265 | 0x05...0x06 => self.mbc_type = MbcType::Mbc2, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:266:17 [INFO] [stdout] | [INFO] [stdout] 266 | 0x0f...0x13 => self.mbc_type = MbcType::Mbc3, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:275:17 [INFO] [stdout] | [INFO] [stdout] 275 | 0x00...0x04 | 7 => normal, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:320:19 [INFO] [stdout] | [INFO] [stdout] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:320:37 [INFO] [stdout] | [INFO] [stdout] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:321:19 [INFO] [stdout] | [INFO] [stdout] 321 | 0x8000...0x9fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:330:19 [INFO] [stdout] | [INFO] [stdout] 330 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000], [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:331:19 [INFO] [stdout] | [INFO] [stdout] 331 | 0xd000...0xdfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:338:19 [INFO] [stdout] | [INFO] [stdout] 338 | 0xe000...0xfdff => self.read(addr - 0x2000), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:339:19 [INFO] [stdout] | [INFO] [stdout] 339 | 0xfe00...0xffff => self.high_ram[addr as usize - 0xfe00], [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:346:19 [INFO] [stdout] | [INFO] [stdout] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:346:37 [INFO] [stdout] | [INFO] [stdout] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:347:19 [INFO] [stdout] | [INFO] [stdout] 347 | 0x8000...0x9fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:356:19 [INFO] [stdout] | [INFO] [stdout] 356 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000] = val, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:357:19 [INFO] [stdout] | [INFO] [stdout] 357 | 0xd000...0xdfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:364:19 [INFO] [stdout] | [INFO] [stdout] 364 | 0xe000...0xfdff => self.write(addr - 0x2000, val), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:365:19 [INFO] [stdout] | [INFO] [stdout] 365 | 0xfe00...0xffff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/mem.rs:426:48 [INFO] [stdout] | [INFO] [stdout] 426 | pub fn load_cartridge(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:64:42 [INFO] [stdout] | [INFO] [stdout] 64 | pub fn load_rom(&mut self, rom: &mut Read) -> Result<(), GbcErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/cpu.rs:560:30 [INFO] [stdout] | [INFO] [stdout] 560 | ... 3...7 => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/cpu.rs:829:30 [INFO] [stdout] | [INFO] [stdout] 829 | ... 0...3 => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/cpu.rs:931:30 [INFO] [stdout] | [INFO] [stdout] 931 | ... 0...3 => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/mem.rs:176:24 [INFO] [stdout] | [INFO] [stdout] 176 | fn read_bank(rom: &mut Read) -> Result<[u8; 0x4000], CartErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:189:19 [INFO] [stdout] | [INFO] [stdout] 189 | 0x0000...0x3fff => self.rom[0][addr as usize], [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:190:19 [INFO] [stdout] | [INFO] [stdout] 190 | 0x4000...0x7fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:211:19 [INFO] [stdout] | [INFO] [stdout] 211 | 0xa000...0xbfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:228:19 [INFO] [stdout] | [INFO] [stdout] 228 | 0x0000...0x1fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:231:19 [INFO] [stdout] | [INFO] [stdout] 231 | 0x2000...0x3fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:235:19 [INFO] [stdout] | [INFO] [stdout] 235 | 0x4000...0x5fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:238:19 [INFO] [stdout] | [INFO] [stdout] 238 | 0x6000...0x7fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:241:19 [INFO] [stdout] | [INFO] [stdout] 241 | 0xa000...0xbfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/mem.rs:256:38 [INFO] [stdout] | [INFO] [stdout] 256 | pub fn load(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:264:17 [INFO] [stdout] | [INFO] [stdout] 264 | 0x01...0x03 => self.mbc_type = MbcType::Mbc1, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:265:17 [INFO] [stdout] | [INFO] [stdout] 265 | 0x05...0x06 => self.mbc_type = MbcType::Mbc2, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:266:17 [INFO] [stdout] | [INFO] [stdout] 266 | 0x0f...0x13 => self.mbc_type = MbcType::Mbc3, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:275:17 [INFO] [stdout] | [INFO] [stdout] 275 | 0x00...0x04 | 7 => normal, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:320:19 [INFO] [stdout] | [INFO] [stdout] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:320:37 [INFO] [stdout] | [INFO] [stdout] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:321:19 [INFO] [stdout] | [INFO] [stdout] 321 | 0x8000...0x9fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:330:19 [INFO] [stdout] | [INFO] [stdout] 330 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000], [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:331:19 [INFO] [stdout] | [INFO] [stdout] 331 | 0xd000...0xdfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:338:19 [INFO] [stdout] | [INFO] [stdout] 338 | 0xe000...0xfdff => self.read(addr - 0x2000), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:339:19 [INFO] [stdout] | [INFO] [stdout] 339 | 0xfe00...0xffff => self.high_ram[addr as usize - 0xfe00], [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:346:19 [INFO] [stdout] | [INFO] [stdout] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:346:37 [INFO] [stdout] | [INFO] [stdout] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:347:19 [INFO] [stdout] | [INFO] [stdout] 347 | 0x8000...0x9fff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:356:19 [INFO] [stdout] | [INFO] [stdout] 356 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000] = val, [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:357:19 [INFO] [stdout] | [INFO] [stdout] 357 | 0xd000...0xdfff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:364:19 [INFO] [stdout] | [INFO] [stdout] 364 | 0xe000...0xfdff => self.write(addr - 0x2000, val), [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `...` range patterns are deprecated [INFO] [stdout] --> src/mem.rs:365:19 [INFO] [stdout] | [INFO] [stdout] 365 | 0xfe00...0xffff => { [INFO] [stdout] | ^^^ help: use `..=` for an inclusive range [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/mem.rs:426:48 [INFO] [stdout] | [INFO] [stdout] 426 | pub fn load_cartridge(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/lib.rs:64:42 [INFO] [stdout] | [INFO] [stdout] 64 | pub fn load_rom(&mut self, rom: &mut Read) -> Result<(), GbcErr> { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/mem.rs:340:13 [INFO] [stdout] | [INFO] [stdout] 340 | _ => panic!("Impossible"), [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/mem.rs:388:13 [INFO] [stdout] | [INFO] [stdout] 388 | _ => panic!("Impossible"), [INFO] [stdout] | ^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/mem.rs:340:13 [INFO] [stdout] | [INFO] [stdout] 340 | _ => panic!("Impossible"), [INFO] [stdout] | ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/mem.rs:388:13 [INFO] [stdout] | [INFO] [stdout] 388 | _ => panic!("Impossible"), [INFO] [stdout] | ^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum is never used: `Button` [INFO] [stdout] --> src/joypad.rs:3:10 [INFO] [stdout] | [INFO] [stdout] 3 | pub enum Button { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `set_button` [INFO] [stdout] --> src/joypad.rs:26:12 [INFO] [stdout] | [INFO] [stdout] 26 | pub fn set_button(&mut self, button: Button, val: bool) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `ext_ram_enabled` [INFO] [stdout] --> src/mem.rs:30:5 [INFO] [stdout] | [INFO] [stdout] 30 | ext_ram_enabled: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `set_interrupt_en` [INFO] [stdout] --> src/mem.rs:400:12 [INFO] [stdout] | [INFO] [stdout] 400 | pub fn set_interrupt_en(&mut self, intr: cpu::Interrupt, set: bool) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `sound` [INFO] [stdout] --> src/lib.rs:32:5 [INFO] [stdout] | [INFO] [stdout] 32 | sound: sound::Sound, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 40 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum is never used: `Button` [INFO] [stdout] --> src/joypad.rs:3:10 [INFO] [stdout] | [INFO] [stdout] 3 | pub enum Button { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `set_button` [INFO] [stdout] --> src/joypad.rs:26:12 [INFO] [stdout] | [INFO] [stdout] 26 | pub fn set_button(&mut self, button: Button, val: bool) { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `ext_ram_enabled` [INFO] [stdout] --> src/mem.rs:30:5 [INFO] [stdout] | [INFO] [stdout] 30 | ext_ram_enabled: bool, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `set_interrupt_en` [INFO] [stdout] --> src/mem.rs:400:12 [INFO] [stdout] | [INFO] [stdout] 400 | pub fn set_interrupt_en(&mut self, intr: cpu::Interrupt, set: bool) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `sound` [INFO] [stdout] --> src/lib.rs:32:5 [INFO] [stdout] | [INFO] [stdout] 32 | sound: sound::Sound, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 40 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:17:32 [INFO] [stdout] | [INFO] [stdout] 17 | cmds: BTreeMap>, [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:34:37 [INFO] [stdout] | [INFO] [stdout] 34 | pub fn run(&mut self, rom: &mut Read) -> bool { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:136:34 [INFO] [stdout] | [INFO] [stdout] 136 | print_usage(self as &Cmd); [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:158:38 [INFO] [stdout] | [INFO] [stdout] 158 | print_usage(self as &Cmd); [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:197:34 [INFO] [stdout] | [INFO] [stdout] 197 | print_usage(self as &Cmd); [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:226:22 [INFO] [stdout] | [INFO] [stdout] 226 | fn print_usage(cmd: &Cmd) { [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:17:32 [INFO] [stdout] | [INFO] [stdout] 17 | cmds: BTreeMap>, [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:34:37 [INFO] [stdout] | [INFO] [stdout] 34 | pub fn run(&mut self, rom: &mut Read) -> bool { [INFO] [stdout] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:136:34 [INFO] [stdout] | [INFO] [stdout] 136 | print_usage(self as &Cmd); [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:158:38 [INFO] [stdout] | [INFO] [stdout] 158 | print_usage(self as &Cmd); [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:197:34 [INFO] [stdout] | [INFO] [stdout] 197 | print_usage(self as &Cmd); [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/client/cli.rs:226:22 [INFO] [stdout] | [INFO] [stdout] 226 | fn print_usage(cmd: &Cmd) { [INFO] [stdout] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cmd` [INFO] [stdout] --> src/client/cli.rs:175:46 [INFO] [stdout] | [INFO] [stdout] 175 | fn run(&mut self, gbc: &mut libgbc::Gbc, cmd: &[&str]) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_cmd` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `parse_u8` [INFO] [stdout] --> src/client/cli.rs:230:4 [INFO] [stdout] | [INFO] [stdout] 230 | fn parse_u8(s: &str) -> Result { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 8 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cmd` [INFO] [stdout] --> src/client/cli.rs:175:46 [INFO] [stdout] | [INFO] [stdout] 175 | fn run(&mut self, gbc: &mut libgbc::Gbc, cmd: &[&str]) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_cmd` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function is never used: `parse_u8` [INFO] [stdout] --> src/client/cli.rs:230:4 [INFO] [stdout] | [INFO] [stdout] 230 | fn parse_u8(s: &str) -> Result { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 8 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.06s [INFO] running `Command { std: "docker" "inspect" "502945439c92aaf81b2b2fb991e4e540d9eb8136e71ba12e4a6e7ef5d52332bf", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "502945439c92aaf81b2b2fb991e4e540d9eb8136e71ba12e4a6e7ef5d52332bf", kill_on_drop: false }` [INFO] [stdout] 502945439c92aaf81b2b2fb991e4e540d9eb8136e71ba12e4a6e7ef5d52332bf