[INFO] updating cached repository baileyforrest/gbc [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/baileyforrest/gbc [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/baileyforrest/gbc" "work/ex/beta-1.38-1/sources/1.37.0/gh/baileyforrest/gbc"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/1.37.0/gh/baileyforrest/gbc'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/baileyforrest/gbc" "work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/baileyforrest/gbc"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/baileyforrest/gbc'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 47b902177d5e3fcfcfb9f9c15c5e1930abca1971 [INFO] sha for GitHub repo baileyforrest/gbc: 47b902177d5e3fcfcfb9f9c15c5e1930abca1971 [INFO] validating manifest of baileyforrest/gbc on toolchain 1.37.0 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of baileyforrest/gbc on toolchain beta-2019-08-13 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing baileyforrest/gbc [INFO] finished frobbing baileyforrest/gbc [INFO] frobbed toml for baileyforrest/gbc written to work/ex/beta-1.38-1/sources/1.37.0/gh/baileyforrest/gbc/Cargo.toml [INFO] started frobbing baileyforrest/gbc [INFO] finished frobbing baileyforrest/gbc [INFO] frobbed toml for baileyforrest/gbc written to work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/baileyforrest/gbc/Cargo.toml [INFO] crate baileyforrest/gbc already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] testing baileyforrest/gbc against 1.37.0 for beta-1.38-1 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-3/1.37.0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/1.37.0/gh/baileyforrest/gbc:/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=warn" "-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" "+1.37.0" "build" "--frozen"` [INFO] [stdout] 6edca0e01b5f930630ac86cc4814825f014a8476716a38347f3c31b32d2032d7 [INFO] running `"docker" "start" "-a" "6edca0e01b5f930630ac86cc4814825f014a8476716a38347f3c31b32d2032d7"` [INFO] [stderr] Compiling gbc v0.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:560:30 [INFO] [stderr] | [INFO] [stderr] 560 | 3...7 => { [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/cpu.rs:829:30 [INFO] [stderr] | [INFO] [stderr] 829 | 0...3 => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:931:30 [INFO] [stderr] | [INFO] [stderr] 931 | 0...3 => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/mem.rs:176:24 [INFO] [stderr] | [INFO] [stderr] 176 | fn read_bank(rom: &mut Read) -> Result<[u8; 0x4000], CartErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:189:19 [INFO] [stderr] | [INFO] [stderr] 189 | 0x0000...0x3fff => self.rom[0][addr as usize], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:190:19 [INFO] [stderr] | [INFO] [stderr] 190 | 0x4000...0x7fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:211:19 [INFO] [stderr] | [INFO] [stderr] 211 | 0xa000...0xbfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:228:19 [INFO] [stderr] | [INFO] [stderr] 228 | 0x0000...0x1fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:231:19 [INFO] [stderr] | [INFO] [stderr] 231 | 0x2000...0x3fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:235:19 [INFO] [stderr] | [INFO] [stderr] 235 | 0x4000...0x5fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:238:19 [INFO] [stderr] | [INFO] [stderr] 238 | 0x6000...0x7fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:241:19 [INFO] [stderr] | [INFO] [stderr] 241 | 0xa000...0xbfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/mem.rs:256:38 [INFO] [stderr] | [INFO] [stderr] 256 | pub fn load(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:264:17 [INFO] [stderr] | [INFO] [stderr] 264 | 0x01...0x03 => self.mbc_type = MbcType::Mbc1, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:265:17 [INFO] [stderr] | [INFO] [stderr] 265 | 0x05...0x06 => self.mbc_type = MbcType::Mbc2, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:266:17 [INFO] [stderr] | [INFO] [stderr] 266 | 0x0f...0x13 => self.mbc_type = MbcType::Mbc3, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:275:17 [INFO] [stderr] | [INFO] [stderr] 275 | 0x00...0x04 | 7 => normal, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:320:19 [INFO] [stderr] | [INFO] [stderr] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:320:37 [INFO] [stderr] | [INFO] [stderr] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:321:19 [INFO] [stderr] | [INFO] [stderr] 321 | 0x8000...0x9fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:330:19 [INFO] [stderr] | [INFO] [stderr] 330 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:331:19 [INFO] [stderr] | [INFO] [stderr] 331 | 0xd000...0xdfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:338:19 [INFO] [stderr] | [INFO] [stderr] 338 | 0xe000...0xfdff => self.read(addr - 0x2000), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:339:19 [INFO] [stderr] | [INFO] [stderr] 339 | 0xfe00...0xffff => self.high_ram[addr as usize - 0xfe00], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:346:19 [INFO] [stderr] | [INFO] [stderr] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:346:37 [INFO] [stderr] | [INFO] [stderr] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:347:19 [INFO] [stderr] | [INFO] [stderr] 347 | 0x8000...0x9fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:356:19 [INFO] [stderr] | [INFO] [stderr] 356 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000] = val, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:357:19 [INFO] [stderr] | [INFO] [stderr] 357 | 0xd000...0xdfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:364:19 [INFO] [stderr] | [INFO] [stderr] 364 | 0xe000...0xfdff => self.write(addr - 0x2000, val), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:365:19 [INFO] [stderr] | [INFO] [stderr] 365 | 0xfe00...0xffff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/mem.rs:426:48 [INFO] [stderr] | [INFO] [stderr] 426 | pub fn load_cartridge(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:64:42 [INFO] [stderr] | [INFO] [stderr] 64 | pub fn load_rom(&mut self, rom: &mut Read) -> Result<(), GbcErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/mem.rs:340:13 [INFO] [stderr] | [INFO] [stderr] 340 | _ => panic!("Impossible"), [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unreachable_patterns)] on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/mem.rs:388:13 [INFO] [stderr] | [INFO] [stderr] 388 | _ => panic!("Impossible"), [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: enum is never used: `Button` [INFO] [stderr] --> src/joypad.rs:3:1 [INFO] [stderr] | [INFO] [stderr] 3 | pub enum Button { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(dead_code)] on by default [INFO] [stderr] [INFO] [stderr] warning: method is never used: `set_button` [INFO] [stderr] --> src/joypad.rs:26:5 [INFO] [stderr] | [INFO] [stderr] 26 | pub fn set_button(&mut self, button: Button, val: bool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `set_interrupt_en` [INFO] [stderr] --> src/mem.rs:400:5 [INFO] [stderr] | [INFO] [stderr] 400 | pub fn set_interrupt_en(&mut self, intr: cpu::Interrupt, set: bool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never used: `sound` [INFO] [stderr] --> src/lib.rs:32:5 [INFO] [stderr] | [INFO] [stderr] 32 | sound: sound::Sound, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:17:32 [INFO] [stderr] | [INFO] [stderr] 17 | cmds: BTreeMap>, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:34:37 [INFO] [stderr] | [INFO] [stderr] 34 | pub fn run(&mut self, rom: &mut Read) -> bool { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:136:34 [INFO] [stderr] | [INFO] [stderr] 136 | print_usage(self as &Cmd); [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:158:38 [INFO] [stderr] | [INFO] [stderr] 158 | print_usage(self as &Cmd); [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:197:34 [INFO] [stderr] | [INFO] [stderr] 197 | print_usage(self as &Cmd); [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:226:22 [INFO] [stderr] | [INFO] [stderr] 226 | fn print_usage(cmd: &Cmd) { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `cmd` [INFO] [stderr] --> src/client/cli.rs:175:46 [INFO] [stderr] | [INFO] [stderr] 175 | fn run(&mut self, gbc: &mut libgbc::Gbc, cmd: &[&str]) { [INFO] [stderr] | ^^^ help: consider prefixing with an underscore: `_cmd` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unused_variables)] on by default [INFO] [stderr] [INFO] [stderr] warning: function is never used: `parse_u8` [INFO] [stderr] --> src/client/cli.rs:230:1 [INFO] [stderr] | [INFO] [stderr] 230 | fn parse_u8(s: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(dead_code)] on by default [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.92s [INFO] running `"docker" "inspect" "6edca0e01b5f930630ac86cc4814825f014a8476716a38347f3c31b32d2032d7"` [INFO] running `"docker" "rm" "-f" "6edca0e01b5f930630ac86cc4814825f014a8476716a38347f3c31b32d2032d7"` [INFO] [stdout] 6edca0e01b5f930630ac86cc4814825f014a8476716a38347f3c31b32d2032d7 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-3/1.37.0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/1.37.0/gh/baileyforrest/gbc:/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=warn" "-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" "+1.37.0" "test" "--frozen" "--no-run"` [INFO] [stdout] 96716397eb8a63eb64042d2ec8eefc75af7161085cb3f9793b30ff89c0a8cf0c [INFO] running `"docker" "start" "-a" "96716397eb8a63eb64042d2ec8eefc75af7161085cb3f9793b30ff89c0a8cf0c"` [INFO] [stderr] Compiling gbc v0.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:560:30 [INFO] [stderr] | [INFO] [stderr] 560 | 3...7 => { [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/cpu.rs:829:30 [INFO] [stderr] | [INFO] [stderr] 829 | 0...3 => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/cpu.rs:931:30 [INFO] [stderr] | [INFO] [stderr] 931 | 0...3 => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/mem.rs:176:24 [INFO] [stderr] | [INFO] [stderr] 176 | fn read_bank(rom: &mut Read) -> Result<[u8; 0x4000], CartErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:189:19 [INFO] [stderr] | [INFO] [stderr] 189 | 0x0000...0x3fff => self.rom[0][addr as usize], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:190:19 [INFO] [stderr] | [INFO] [stderr] 190 | 0x4000...0x7fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:211:19 [INFO] [stderr] | [INFO] [stderr] 211 | 0xa000...0xbfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:228:19 [INFO] [stderr] | [INFO] [stderr] 228 | 0x0000...0x1fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:231:19 [INFO] [stderr] | [INFO] [stderr] 231 | 0x2000...0x3fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:235:19 [INFO] [stderr] | [INFO] [stderr] 235 | 0x4000...0x5fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:238:19 [INFO] [stderr] | [INFO] [stderr] 238 | 0x6000...0x7fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:241:19 [INFO] [stderr] | [INFO] [stderr] 241 | 0xa000...0xbfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/mem.rs:256:38 [INFO] [stderr] | [INFO] [stderr] 256 | pub fn load(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:264:17 [INFO] [stderr] | [INFO] [stderr] 264 | 0x01...0x03 => self.mbc_type = MbcType::Mbc1, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:265:17 [INFO] [stderr] | [INFO] [stderr] 265 | 0x05...0x06 => self.mbc_type = MbcType::Mbc2, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:266:17 [INFO] [stderr] | [INFO] [stderr] 266 | 0x0f...0x13 => self.mbc_type = MbcType::Mbc3, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:275:17 [INFO] [stderr] | [INFO] [stderr] 275 | 0x00...0x04 | 7 => normal, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:320:19 [INFO] [stderr] | [INFO] [stderr] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:320:37 [INFO] [stderr] | [INFO] [stderr] 320 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.read(addr), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:321:19 [INFO] [stderr] | [INFO] [stderr] 321 | 0x8000...0x9fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:330:19 [INFO] [stderr] | [INFO] [stderr] 330 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:331:19 [INFO] [stderr] | [INFO] [stderr] 331 | 0xd000...0xdfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:338:19 [INFO] [stderr] | [INFO] [stderr] 338 | 0xe000...0xfdff => self.read(addr - 0x2000), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:339:19 [INFO] [stderr] | [INFO] [stderr] 339 | 0xfe00...0xffff => self.high_ram[addr as usize - 0xfe00], [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:346:19 [INFO] [stderr] | [INFO] [stderr] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:346:37 [INFO] [stderr] | [INFO] [stderr] 346 | 0x0000...0x7fff | 0xa000...0xbfff => self.cartridge.write(addr, val), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:347:19 [INFO] [stderr] | [INFO] [stderr] 347 | 0x8000...0x9fff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:356:19 [INFO] [stderr] | [INFO] [stderr] 356 | 0xc000...0xcfff => self.work_ram[0][addr as usize - 0xc000] = val, [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:357:19 [INFO] [stderr] | [INFO] [stderr] 357 | 0xd000...0xdfff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:364:19 [INFO] [stderr] | [INFO] [stderr] 364 | 0xe000...0xfdff => self.write(addr - 0x2000, val), [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: `...` range patterns are deprecated [INFO] [stderr] --> src/mem.rs:365:19 [INFO] [stderr] | [INFO] [stderr] 365 | 0xfe00...0xffff => { [INFO] [stderr] | ^^^ help: use `..=` for an inclusive range [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/mem.rs:426:48 [INFO] [stderr] | [INFO] [stderr] 426 | pub fn load_cartridge(&mut self, rom: &mut Read) -> Result<(), CartErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:64:42 [INFO] [stderr] | [INFO] [stderr] 64 | pub fn load_rom(&mut self, rom: &mut Read) -> Result<(), GbcErr> { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:17:32 [INFO] [stderr] | [INFO] [stderr] 17 | cmds: BTreeMap>, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(bare_trait_objects)] on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:34:37 [INFO] [stderr] | [INFO] [stderr] 34 | pub fn run(&mut self, rom: &mut Read) -> bool { [INFO] [stderr] | ^^^^ help: use `dyn`: `dyn Read` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:136:34 [INFO] [stderr] | [INFO] [stderr] 136 | print_usage(self as &Cmd); [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:158:38 [INFO] [stderr] | [INFO] [stderr] 158 | print_usage(self as &Cmd); [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:197:34 [INFO] [stderr] | [INFO] [stderr] 197 | print_usage(self as &Cmd); [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/client/cli.rs:226:22 [INFO] [stderr] | [INFO] [stderr] 226 | fn print_usage(cmd: &Cmd) { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Cmd` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `cmd` [INFO] [stderr] --> src/client/cli.rs:175:46 [INFO] [stderr] | [INFO] [stderr] 175 | fn run(&mut self, gbc: &mut libgbc::Gbc, cmd: &[&str]) { [INFO] [stderr] | ^^^ help: consider prefixing with an underscore: `_cmd` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unused_variables)] on by default [INFO] [stderr] [INFO] [stderr] warning: function is never used: `parse_u8` [INFO] [stderr] --> src/client/cli.rs:230:1 [INFO] [stderr] | [INFO] [stderr] 230 | fn parse_u8(s: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(dead_code)] on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/mem.rs:340:13 [INFO] [stderr] | [INFO] [stderr] 340 | _ => panic!("Impossible"), [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unreachable_patterns)] on by default [INFO] [stderr] [INFO] [stderr] warning: unreachable pattern [INFO] [stderr] --> src/mem.rs:388:13 [INFO] [stderr] | [INFO] [stderr] 388 | _ => panic!("Impossible"), [INFO] [stderr] | ^ [INFO] [stderr] [INFO] [stderr] warning: enum is never used: `Button` [INFO] [stderr] --> src/joypad.rs:3:1 [INFO] [stderr] | [INFO] [stderr] 3 | pub enum Button { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(dead_code)] on by default [INFO] [stderr] [INFO] [stderr] warning: method is never used: `set_button` [INFO] [stderr] --> src/joypad.rs:26:5 [INFO] [stderr] | [INFO] [stderr] 26 | pub fn set_button(&mut self, button: Button, val: bool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `set_interrupt_en` [INFO] [stderr] --> src/mem.rs:400:5 [INFO] [stderr] | [INFO] [stderr] 400 | pub fn set_interrupt_en(&mut self, intr: cpu::Interrupt, set: bool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never used: `sound` [INFO] [stderr] --> src/lib.rs:32:5 [INFO] [stderr] | [INFO] [stderr] 32 | sound: sound::Sound, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.84s [INFO] running `"docker" "inspect" "96716397eb8a63eb64042d2ec8eefc75af7161085cb3f9793b30ff89c0a8cf0c"` [INFO] running `"docker" "rm" "-f" "96716397eb8a63eb64042d2ec8eefc75af7161085cb3f9793b30ff89c0a8cf0c"` [INFO] [stdout] 96716397eb8a63eb64042d2ec8eefc75af7161085cb3f9793b30ff89c0a8cf0c [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-3/1.37.0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/1.37.0/gh/baileyforrest/gbc:/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=warn" "-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" "+1.37.0" "test" "--frozen"` [INFO] [stdout] 14ad5e1f10e7848374490b135a67d36d6eee7941c042a781e1cbf7c3a23e5b2f [INFO] running `"docker" "start" "-a" "14ad5e1f10e7848374490b135a67d36d6eee7941c042a781e1cbf7c3a23e5b2f"` [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.01s [INFO] [stderr] Running /opt/crater/target/debug/deps/libgbc-d143dba676b7ff21 [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Running /opt/crater/target/debug/deps/gbc-7136634a955b45cb [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] Doc-tests libgbc [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] running `"docker" "inspect" "14ad5e1f10e7848374490b135a67d36d6eee7941c042a781e1cbf7c3a23e5b2f"` [INFO] running `"docker" "rm" "-f" "14ad5e1f10e7848374490b135a67d36d6eee7941c042a781e1cbf7c3a23e5b2f"` [INFO] [stdout] 14ad5e1f10e7848374490b135a67d36d6eee7941c042a781e1cbf7c3a23e5b2f