[INFO] cloning repository https://github.com/MoefulYe/gameboy-tui
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/MoefulYe/gameboy-tui" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMoefulYe%2Fgameboy-tui", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMoefulYe%2Fgameboy-tui'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 039d14d4b77b49ced3278ad5f9a1c4a1e1e82d80
[INFO] testing MoefulYe/gameboy-tui against try#33835004928d3bf65db4d4712e1330766263b0bd for pr-155739
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMoefulYe%2Fgameboy-tui" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/MoefulYe/gameboy-tui
[INFO] finished tweaking git repo https://github.com/MoefulYe/gameboy-tui
[INFO] tweaked toml for git repo https://github.com/MoefulYe/gameboy-tui written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/MoefulYe/gameboy-tui on toolchain 33835004928d3bf65db4d4712e1330766263b0bd
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/MoefulYe/gameboy-tui already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f5e2193ff4aad8fafa5b1fb6a7d3c37189083fd45128d643311b828f05ce1aa4
[INFO] running `Command { std: "docker" "start" "-a" "f5e2193ff4aad8fafa5b1fb6a7d3c37189083fd45128d643311b828f05ce1aa4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f5e2193ff4aad8fafa5b1fb6a7d3c37189083fd45128d643311b828f05ce1aa4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f5e2193ff4aad8fafa5b1fb6a7d3c37189083fd45128d643311b828f05ce1aa4", kill_on_drop: false }`
[INFO] [stdout] f5e2193ff4aad8fafa5b1fb6a7d3c37189083fd45128d643311b828f05ce1aa4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 190cec46a6d9db1570ec794eb03d854802d5d6cabe84f48f5ee39a359c7f08e6
[INFO] running `Command { std: "docker" "start" "-a" "190cec46a6d9db1570ec794eb03d854802d5d6cabe84f48f5ee39a359c7f08e6", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.184
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling cc v1.2.59
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]    Compiling bytemuck v1.25.0
[INFO] [stderr]    Compiling bitflags v2.11.0
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling aho-corasick v1.1.4
[INFO] [stderr]    Compiling syn v2.0.117
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling regex-syntax v0.8.10
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling tinyvec_macros v0.1.1
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling ogg v0.8.0
[INFO] [stderr]    Compiling tinyvec v1.11.0
[INFO] [stderr]    Compiling symphonia-core v0.5.5
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling unicode-segmentation v1.13.2
[INFO] [stderr]    Compiling dasp_sample v0.11.0
[INFO] [stderr]    Compiling itertools v0.12.1
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling lewton v0.10.2
[INFO] [stderr]    Compiling claxon v0.4.3
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling hound v3.5.1
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling iana-time-zone v0.1.65
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling jiff v0.2.23
[INFO] [stderr]    Compiling compact_str v0.7.1
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling crossbeam v0.8.4
[INFO] [stderr]    Compiling ringbuf v0.4.8
[INFO] [stderr]    Compiling symphonia-metadata v0.5.5
[INFO] [stderr]    Compiling libz-sys v1.1.28
[INFO] [stderr]    Compiling errno v0.3.14
[INFO] [stderr]    Compiling mio v0.8.11
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling alsa v0.9.1
[INFO] [stderr]    Compiling symphonia-bundle-mp3 v0.5.5
[INFO] [stderr]    Compiling flate2 v1.1.9
[INFO] [stderr]    Compiling signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling symphonia v0.5.5
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling rodio v0.17.3
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling stability v0.2.1
[INFO] [stderr]    Compiling clap_derive v4.6.0
[INFO] [stderr]    Compiling env_filter v1.0.1
[INFO] [stderr]    Compiling env_logger v0.11.10
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling clap v4.6.0
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling serde_with_macros v3.18.0
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling bincode v1.3.3
[INFO] [stderr]    Compiling parking_lot_core v0.9.12
[INFO] [stderr]    Compiling parking_lot v0.12.5
[INFO] [stderr]    Compiling serde_with v3.18.0
[INFO] [stderr]    Compiling crossterm v0.27.0
[INFO] [stderr]    Compiling ratatui v0.26.3
[INFO] [stderr]    Compiling gameboy-core v0.1.0 (/opt/rustwide/workdir/core)
[INFO] [stdout] warning: unused import: `int_regs::IRQ`
[INFO] [stdout]  --> core/src/dev/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use int_regs::IRQ;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::debug`
[INFO] [stdout]  --> core/src/dev/apu/modulation.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::debug;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `error`
[INFO] [stdout]  --> core/src/dev/cart/mod.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error};
[INFO] [stdout]   |           ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `error`
[INFO] [stdout]   --> core/src/dev/cart/mbc/mbc1.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use log::{debug, error, warn};
[INFO] [stdout]    |           ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dev::Reset`
[INFO] [stdout]  --> core/src/dev/ppu/lcds.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     dev::Reset,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_with::serde_as`
[INFO] [stdout]  --> core/src/dev/rams.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_with::serde_as;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Reset`
[INFO] [stdout]  --> core/src/dev/serial.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 |     MemoryRegion, Reset,
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ops::Range`
[INFO] [stdout]  --> core/src/utils/bytes.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     ops::Range,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]   --> core/src/dev/cart/mbc/mod.rs:41:37
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn write(&mut self, addr: Addr, data: Word) {
[INFO] [stdout]    |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `halt_mut` and `day_master_bit` are never used
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout]  27 | impl RTC {
[INFO] [stdout]     | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     fn day_master_bit(&self) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> core/src/dev/cpu/ime.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl InterruptMasterEnableRegsiter {
[INFO] [stdout]    | ---------------------------------- associated function in this implementation
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:108:25
[INFO] [stdout]     |
[INFO] [stdout] 108 |     fn day_overflow_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 108 |     fn day_overflow_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:116:17
[INFO] [stdout]     |
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                 ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:124:27
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:241:26
[INFO] [stdout]     |
[INFO] [stdout] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                          ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:251:30
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                              ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:261:32
[INFO] [stdout]     |
[INFO] [stdout] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                                ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                      ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:271:27
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> core/src/dev/ppu/lcds.rs:61:25
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]    |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]    |                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling gameboy-tui v0.1.0 (/opt/rustwide/workdir/tui)
[INFO] [stdout] warning: unused import: `anyhow::Result`
[INFO] [stdout]  --> tui/src/app.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::Result;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Observer`
[INFO] [stdout]  --> tui/src/output/audio.rs:2:34
[INFO] [stdout]   |
[INFO] [stdout] 2 | use ringbuf::{traits::{Consumer, Observer, Producer, Split}, HeapRb};
[INFO] [stdout]   |                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `audio::NoopAudioOutput`
[INFO] [stdout]  --> tui/src/output/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use audio::NoopAudioOutput;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_frame_duration`
[INFO] [stdout]    --> tui/src/thread.rs:126:13
[INFO] [stdout]     |
[INFO] [stdout] 126 |         let base_frame_duration = Duration::from_micros(16742); // ~59.7 FPS
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_frame_duration`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rom_path`
[INFO] [stdout]    --> tui/src/main.rs:355:5
[INFO] [stdout]     |
[INFO] [stdout] 355 |     rom_path: &std::path::Path,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rom_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoopAudioOutput` is never constructed
[INFO] [stdout]   --> tui/src/output/audio.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct NoopAudioOutput;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> tui/src/output/audio.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl NoopAudioOutput {
[INFO] [stdout]    | -------------------- associated function in this implementation
[INFO] [stdout] 15 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `sink` is never read
[INFO] [stdout]   --> tui/src/output/audio.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct RodioAudioOutput {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 28 |     _stream: OutputStream,
[INFO] [stdout] 29 |     sink: Sink,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `frame_number` is never read
[INFO] [stdout]   --> tui/src/thread.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct FrameData {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 14 |     pub screen_buffer: Vec<Vec<crate::output::screen::Cell>>,
[INFO] [stdout] 15 |     pub frame_number: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FrameData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 9.41s
[INFO] running `Command { std: "docker" "inspect" "190cec46a6d9db1570ec794eb03d854802d5d6cabe84f48f5ee39a359c7f08e6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "190cec46a6d9db1570ec794eb03d854802d5d6cabe84f48f5ee39a359c7f08e6", kill_on_drop: false }`
[INFO] [stdout] 190cec46a6d9db1570ec794eb03d854802d5d6cabe84f48f5ee39a359c7f08e6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 1710da84c10ac9ba6635f7e12aafdc5f9f52d767b3a5734f83e8a054b0a25149
[INFO] running `Command { std: "docker" "start" "-a" "1710da84c10ac9ba6635f7e12aafdc5f9f52d767b3a5734f83e8a054b0a25149", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `int_regs::IRQ`
[INFO] [stdout]  --> core/src/dev/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use int_regs::IRQ;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::debug`
[INFO] [stdout]  --> core/src/dev/apu/modulation.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::debug;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `error`
[INFO] [stdout]  --> core/src/dev/cart/mod.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error};
[INFO] [stdout]   |           ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `error`
[INFO] [stdout]   --> core/src/dev/cart/mbc/mbc1.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use log::{debug, error, warn};
[INFO] [stdout]    |           ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dev::Reset`
[INFO] [stdout]  --> core/src/dev/ppu/lcds.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     dev::Reset,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_with::serde_as`
[INFO] [stdout]  --> core/src/dev/rams.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_with::serde_as;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Reset`
[INFO] [stdout]  --> core/src/dev/serial.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 |     MemoryRegion, Reset,
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ops::Range`
[INFO] [stdout]  --> core/src/utils/bytes.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     ops::Range,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]   --> core/src/dev/cart/mbc/mod.rs:41:37
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn write(&mut self, addr: Addr, data: Word) {
[INFO] [stdout]    |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `halt_mut` and `day_master_bit` are never used
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout]  27 | impl RTC {
[INFO] [stdout]     | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     fn day_master_bit(&self) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> core/src/dev/cpu/ime.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl InterruptMasterEnableRegsiter {
[INFO] [stdout]    | ---------------------------------- associated function in this implementation
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:108:25
[INFO] [stdout]     |
[INFO] [stdout] 108 |     fn day_overflow_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 108 |     fn day_overflow_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:116:17
[INFO] [stdout]     |
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                 ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:124:27
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:241:26
[INFO] [stdout]     |
[INFO] [stdout] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                          ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:251:30
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                              ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:261:32
[INFO] [stdout]     |
[INFO] [stdout] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                                ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                      ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:271:27
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> core/src/dev/ppu/lcds.rs:61:25
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]    |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]    |                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling gameboy-core v0.1.0 (/opt/rustwide/workdir/core)
[INFO] [stderr]    Compiling gameboy-tui v0.1.0 (/opt/rustwide/workdir/tui)
[INFO] [stdout] warning: unused import: `anyhow::Result`
[INFO] [stdout]  --> tui/src/app.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use anyhow::Result;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Observer`
[INFO] [stdout]  --> tui/src/output/audio.rs:2:34
[INFO] [stdout]   |
[INFO] [stdout] 2 | use ringbuf::{traits::{Consumer, Observer, Producer, Split}, HeapRb};
[INFO] [stdout]   |                                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `audio::NoopAudioOutput`
[INFO] [stdout]  --> tui/src/output/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use audio::NoopAudioOutput;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `int_regs::IRQ`
[INFO] [stdout]  --> core/src/dev/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use int_regs::IRQ;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::debug`
[INFO] [stdout]  --> core/src/dev/apu/modulation.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use log::debug;
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `error`
[INFO] [stdout]  --> core/src/dev/cart/mod.rs:8:11
[INFO] [stdout]   |
[INFO] [stdout] 8 | use log::{debug, error};
[INFO] [stdout]   |           ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `debug` and `error`
[INFO] [stdout]   --> core/src/dev/cart/mbc/mbc1.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | use log::{debug, error, warn};
[INFO] [stdout]    |           ^^^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dev::Reset`
[INFO] [stdout]  --> core/src/dev/ppu/lcds.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     dev::Reset,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_with::serde_as`
[INFO] [stdout]  --> core/src/dev/rams.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde_with::serde_as;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Reset`
[INFO] [stdout]  --> core/src/dev/serial.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 |     MemoryRegion, Reset,
[INFO] [stdout]   |                   ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ops::Range`
[INFO] [stdout]  --> core/src/utils/bytes.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 |     ops::Range,
[INFO] [stdout]   |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_frame_duration`
[INFO] [stdout]    --> tui/src/thread.rs:126:13
[INFO] [stdout]     |
[INFO] [stdout] 126 |         let base_frame_duration = Duration::from_micros(16742); // ~59.7 FPS
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_frame_duration`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rom_path`
[INFO] [stdout]    --> tui/src/main.rs:355:5
[INFO] [stdout]     |
[INFO] [stdout] 355 |     rom_path: &std::path::Path,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rom_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoopAudioOutput` is never constructed
[INFO] [stdout]   --> tui/src/output/audio.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct NoopAudioOutput;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> tui/src/output/audio.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl NoopAudioOutput {
[INFO] [stdout]    | -------------------- associated function in this implementation
[INFO] [stdout] 15 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `sink` is never read
[INFO] [stdout]   --> tui/src/output/audio.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub struct RodioAudioOutput {
[INFO] [stdout]    |            ---------------- field in this struct
[INFO] [stdout] 28 |     _stream: OutputStream,
[INFO] [stdout] 29 |     sink: Sink,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `frame_number` is never read
[INFO] [stdout]   --> tui/src/thread.rs:15:9
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub struct FrameData {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 14 |     pub screen_buffer: Vec<Vec<crate::output::screen::Cell>>,
[INFO] [stdout] 15 |     pub frame_number: u64,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FrameData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]   --> core/src/dev/cart/mbc/mod.rs:41:37
[INFO] [stdout]    |
[INFO] [stdout] 41 |     fn write(&mut self, addr: Addr, data: Word) {
[INFO] [stdout]    |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `halt_mut` and `day_master_bit` are never used
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout]  27 | impl RTC {
[INFO] [stdout]     | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 128 |     fn day_master_bit(&self) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> core/src/dev/cpu/ime.rs:19:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl InterruptMasterEnableRegsiter {
[INFO] [stdout]    | ---------------------------------- associated function in this implementation
[INFO] [stdout] 19 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:108:25
[INFO] [stdout]     |
[INFO] [stdout] 108 |     fn day_overflow_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                         |
[INFO] [stdout]     |                         the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 108 |     fn day_overflow_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:116:17
[INFO] [stdout]     |
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                 ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 116 |     fn halt_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                       ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cart/mbc/rtc.rs:124:27
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:241:26
[INFO] [stdout]     |
[INFO] [stdout] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                          ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:251:30
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                              ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                              |
[INFO] [stdout]     |                              the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:261:32
[INFO] [stdout]     |
[INFO] [stdout] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                                ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                                |
[INFO] [stdout]     |                                the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                      ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> core/src/dev/cpu/regs.rs:271:27
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                           |
[INFO] [stdout]     |                           the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]     |                                                 ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> core/src/dev/ppu/lcds.rs:61:25
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy {
[INFO] [stdout]    |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                         |
[INFO] [stdout]    |                         the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stdout]    |                                               ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.14s
[INFO] running `Command { std: "docker" "inspect" "1710da84c10ac9ba6635f7e12aafdc5f9f52d767b3a5734f83e8a054b0a25149", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1710da84c10ac9ba6635f7e12aafdc5f9f52d767b3a5734f83e8a054b0a25149", kill_on_drop: false }`
[INFO] [stdout] 1710da84c10ac9ba6635f7e12aafdc5f9f52d767b3a5734f83e8a054b0a25149
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+33835004928d3bf65db4d4712e1330766263b0bd" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 7a7a54dd0440a13efb8273533fd5155108be22d9fdd2bb2434081c6377170a25
[INFO] running `Command { std: "docker" "start" "-a" "7a7a54dd0440a13efb8273533fd5155108be22d9fdd2bb2434081c6377170a25", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `int_regs::IRQ`
[INFO] [stderr]  --> core/src/dev/mod.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use int_regs::IRQ;
[INFO] [stderr]   |     ^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `log::debug`
[INFO] [stderr]  --> core/src/dev/apu/modulation.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use log::debug;
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `debug` and `error`
[INFO] [stderr]  --> core/src/dev/cart/mod.rs:8:11
[INFO] [stderr]   |
[INFO] [stderr] 8 | use log::{debug, error};
[INFO] [stderr]   |           ^^^^^  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `debug` and `error`
[INFO] [stderr]   --> core/src/dev/cart/mbc/mbc1.rs:10:11
[INFO] [stderr]    |
[INFO] [stderr] 10 | use log::{debug, error, warn};
[INFO] [stderr]    |           ^^^^^  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `dev::Reset`
[INFO] [stderr]  --> core/src/dev/ppu/lcds.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 |     dev::Reset,
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `serde_with::serde_as`
[INFO] [stderr]  --> core/src/dev/rams.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use serde_with::serde_as;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Reset`
[INFO] [stderr]  --> core/src/dev/serial.rs:3:19
[INFO] [stderr]   |
[INFO] [stderr] 3 |     MemoryRegion, Reset,
[INFO] [stderr]   |                   ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ops::Range`
[INFO] [stderr]  --> core/src/utils/bytes.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 |     ops::Range,
[INFO] [stderr]   |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `data`
[INFO] [stderr]   --> core/src/dev/cart/mbc/mod.rs:41:37
[INFO] [stderr]    |
[INFO] [stderr] 41 |     fn write(&mut self, addr: Addr, data: Word) {
[INFO] [stderr]    |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `halt_mut` and `day_master_bit` are never used
[INFO] [stderr]    --> core/src/dev/cart/mbc/rtc.rs:116:8
[INFO] [stderr]     |
[INFO] [stderr]  27 | impl RTC {
[INFO] [stderr]     | -------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |        ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 128 |     fn day_master_bit(&self) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> core/src/dev/cpu/ime.rs:19:12
[INFO] [stderr]    |
[INFO] [stderr] 18 | impl InterruptMasterEnableRegsiter {
[INFO] [stderr]    | ---------------------------------- associated function in this implementation
[INFO] [stderr] 19 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cart/mbc/rtc.rs:108:25
[INFO] [stderr]     |
[INFO] [stderr] 108 |     fn day_overflow_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                         |
[INFO] [stderr]     |                         the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 108 |     fn day_overflow_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                               ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cart/mbc/rtc.rs:116:17
[INFO] [stderr]     |
[INFO] [stderr] 116 |     fn halt_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                 ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 116 |     fn halt_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                       ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cart/mbc/rtc.rs:124:27
[INFO] [stderr]     |
[INFO] [stderr] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                           |
[INFO] [stderr]     |                           the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 124 |     fn day_master_bit_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                                 ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cpu/regs.rs:241:26
[INFO] [stderr]     |
[INFO] [stderr] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                          ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                          |
[INFO] [stderr]     |                          the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 241 |     pub fn zero_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                                ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cpu/regs.rs:251:30
[INFO] [stderr]     |
[INFO] [stderr] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                              ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                              |
[INFO] [stderr]     |                              the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 251 |     pub fn negative_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                                    ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cpu/regs.rs:261:32
[INFO] [stderr]     |
[INFO] [stderr] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                                ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                                |
[INFO] [stderr]     |                                the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 261 |     pub fn half_carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                                      ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]    --> core/src/dev/cpu/regs.rs:271:27
[INFO] [stderr]     |
[INFO] [stderr] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy {
[INFO] [stderr]     |                           ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]     |                           |
[INFO] [stderr]     |                           the lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]     |
[INFO] [stderr] 271 |     pub fn carry_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]     |                                                 ++++
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> core/src/dev/ppu/lcds.rs:61:25
[INFO] [stderr]    |
[INFO] [stderr] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy {
[INFO] [stderr]    |                         ^^^^^^^^^     ^^^^^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                         |
[INFO] [stderr]    |                         the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 61 |     pub fn lyc_flag_mut(&mut self) -> BitProxy<'_> {
[INFO] [stderr]    |                                               ++++
[INFO] [stderr] 
[INFO] [stderr] warning: `gameboy-core` (lib) generated 19 warnings (run `cargo fix --lib -p gameboy-core` to apply 17 suggestions)
[INFO] [stderr] warning: `gameboy-core` (lib test) generated 19 warnings (19 duplicates)
[INFO] [stderr] warning: unused import: `anyhow::Result`
[INFO] [stderr]  --> tui/src/app.rs:1:5
[INFO] [stderr]   |
[INFO] [stderr] 1 | use anyhow::Result;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Observer`
[INFO] [stderr]  --> tui/src/output/audio.rs:2:34
[INFO] [stderr]   |
[INFO] [stderr] 2 | use ringbuf::{traits::{Consumer, Observer, Producer, Split}, HeapRb};
[INFO] [stderr]   |                                  ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `audio::NoopAudioOutput`
[INFO] [stderr]  --> tui/src/output/mod.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub use audio::NoopAudioOutput;
[INFO] [stderr]   |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `base_frame_duration`
[INFO] [stderr]    --> tui/src/thread.rs:126:13
[INFO] [stderr]     |
[INFO] [stderr] 126 |         let base_frame_duration = Duration::from_micros(16742); // ~59.7 FPS
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_frame_duration`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `rom_path`
[INFO] [stderr]    --> tui/src/main.rs:355:5
[INFO] [stderr]     |
[INFO] [stderr] 355 |     rom_path: &std::path::Path,
[INFO] [stderr]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_rom_path`
[INFO] [stderr] 
[INFO] [stderr] warning: struct `NoopAudioOutput` is never constructed
[INFO] [stderr]   --> tui/src/output/audio.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct NoopAudioOutput;
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `new` is never used
[INFO] [stderr]   --> tui/src/output/audio.rs:15:12
[INFO] [stderr]    |
[INFO] [stderr] 14 | impl NoopAudioOutput {
[INFO] [stderr]    | -------------------- associated function in this implementation
[INFO] [stderr] 15 |     pub fn new() -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `sink` is never read
[INFO] [stderr]   --> tui/src/output/audio.rs:29:5
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub struct RodioAudioOutput {
[INFO] [stderr]    |            ---------------- field in this struct
[INFO] [stderr] 28 |     _stream: OutputStream,
[INFO] [stderr] 29 |     sink: Sink,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `frame_number` is never read
[INFO] [stderr]   --> tui/src/thread.rs:15:9
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub struct FrameData {
[INFO] [stderr]    |            --------- field in this struct
[INFO] [stderr] 14 |     pub screen_buffer: Vec<Vec<crate::output::screen::Cell>>,
[INFO] [stderr] 15 |     pub frame_number: u64,
[INFO] [stderr]    |         ^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FrameData` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: `gameboy-tui` (bin "gameboy-tui" test) generated 9 warnings (run `cargo fix --bin "gameboy-tui" -p gameboy-tui --tests` to apply 5 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.11s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/gameboy_core-90af6ed42b319966)
[INFO] [stdout] 
[INFO] [stdout] running 1 test
[INFO] [stdout] test dev::cart::header::test::test ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- dev::cart::header::test::test stdout ----
[INFO] [stdout] reading roms from ../public/roms
[INFO] [stdout] 
[INFO] [stdout] thread 'dev::cart::header::test::test' (18) panicked at core/src/dev/cart/header.rs:467:14:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Os { code: 2, kind: NotFound, message: "No such file or directory" }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x57384009b1aa - std[ec419fa8110287d5]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x57384009b1aa - std[ec419fa8110287d5]::backtrace_rs::backtrace::trace_unsynchronized::<std[ec419fa8110287d5]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x57384009b1aa - std[ec419fa8110287d5]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x57384009b1aa - <<std[ec419fa8110287d5]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[35159d6ffb30e017]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x5738400af1fa - <core[35159d6ffb30e017]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x5738400af1fa - core[35159d6ffb30e017]::fmt::write
[INFO] [stdout]    6:     0x57384009fc32 - std[ec419fa8110287d5]::io::default_write_fmt::<alloc[a8a7aba520129d98]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/io/mod.rs:621:11
[INFO] [stdout]    7:     0x57384009fc32 - <alloc[a8a7aba520129d98]::vec::Vec<u8> as std[ec419fa8110287d5]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/io/mod.rs:1976:13
[INFO] [stdout]    8:     0x573840079a7f - <std[ec419fa8110287d5]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x573840079a7f - std[ec419fa8110287d5]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x573840093179 - std[ec419fa8110287d5]::panicking::default_hook
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x57384002e46c - <alloc[a8a7aba520129d98]::boxed::Box<dyn for<'a, 'b> core[35159d6ffb30e017]::ops::function::Fn<(&'a std[ec419fa8110287d5]::panic::PanicHookInfo<'b>,), Output = ()> + core[35159d6ffb30e017]::marker::Sync + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::Fn<(&std[ec419fa8110287d5]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   12:     0x57384002e46c - test[a8007afcd3effadc]::test_main_inner::<test[a8007afcd3effadc]::test_main_static::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:155:21
[INFO] [stdout]   13:     0x573840093332 - <alloc[a8a7aba520129d98]::boxed::Box<dyn for<'a, 'b> core[35159d6ffb30e017]::ops::function::Fn<(&'a std[ec419fa8110287d5]::panic::PanicHookInfo<'b>,), Output = ()> + core[35159d6ffb30e017]::marker::Sync + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::Fn<(&std[ec419fa8110287d5]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2285:9
[INFO] [stdout]   14:     0x573840093332 - std[ec419fa8110287d5]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x573840079b38 - std[ec419fa8110287d5]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x5738400712f9 - std[ec419fa8110287d5]::sys::backtrace::__rust_end_short_backtrace::<std[ec419fa8110287d5]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x57384007a84d - __rustc[cfb3622dd870db93]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x5738400af94c - core[35159d6ffb30e017]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x5738400af6c2 - core[35159d6ffb30e017]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x57384001f9fd - <core[35159d6ffb30e017]::result::Result<std[ec419fa8110287d5]::fs::ReadDir, std[ec419fa8110287d5]::io::error::Error>>::unwrap
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/result.rs:1233:23
[INFO] [stdout]   21:     0x57384001f9fd - gameboy_core[ec06b2f564cb2d3a]::dev::cart::header::test::read_roms
[INFO] [stdout]                                at /opt/rustwide/workdir/core/src/dev/cart/header.rs:467:14
[INFO] [stdout]   22:     0x57384001fadf - gameboy_core[ec06b2f564cb2d3a]::dev::cart::header::test::test
[INFO] [stdout]                                at /opt/rustwide/workdir/core/src/dev/cart/header.rs:477:20
[INFO] [stdout]   23:     0x57384001d797 - gameboy_core[ec06b2f564cb2d3a]::dev::cart::header::test::test::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/core/src/dev/cart/header.rs:473:14
[INFO] [stdout]   24:     0x573840020a76 - <gameboy_core[ec06b2f564cb2d3a]::dev::cart::header::test::test::{closure#0} as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x57384002174b - <fn() -> core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   26:     0x57384002174b - test[a8007afcd3effadc]::__rust_begin_short_backtrace::<core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>, fn() -> core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:724:18
[INFO] [stdout]   27:     0x57384002ef3b - test[a8007afcd3effadc]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:74
[INFO] [stdout]   28:     0x57384002ef3b - <core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   29:     0x57384002ef3b - std[ec419fa8110287d5]::panicking::catch_unwind::do_call::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>, core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   30:     0x57384002ef3b - std[ec419fa8110287d5]::panicking::catch_unwind::<core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>, core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   31:     0x57384002ef3b - std[ec419fa8110287d5]::panic::catch_unwind::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<test[a8007afcd3effadc]::run_test_in_process::{closure#0}>, core[35159d6ffb30e017]::result::Result<(), alloc[a8a7aba520129d98]::string::String>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   32:     0x57384002ef3b - test[a8007afcd3effadc]::run_test_in_process
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:747:27
[INFO] [stdout]   33:     0x57384002ef3b - test[a8007afcd3effadc]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:668:43
[INFO] [stdout]   34:     0x573840029914 - test[a8007afcd3effadc]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/test/src/lib.rs:698:41
[INFO] [stdout]   35:     0x573840029914 - std[ec419fa8110287d5]::sys::backtrace::__rust_begin_short_backtrace::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   36:     0x573840031b42 - std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:70:13
[INFO] [stdout]   37:     0x573840031b42 - <core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/panic/unwind_safe.rs:275:9
[INFO] [stdout]   38:     0x573840031b42 - std[ec419fa8110287d5]::panicking::catch_unwind::do_call::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:581:40
[INFO] [stdout]   39:     0x573840031b42 - std[ec419fa8110287d5]::panicking::catch_unwind::<(), core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panicking.rs:544:19
[INFO] [stdout]   40:     0x573840031b42 - std[ec419fa8110287d5]::panic::catch_unwind::<core[35159d6ffb30e017]::panic::unwind_safe::AssertUnwindSafe<std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/panic.rs:359:14
[INFO] [stdout]   41:     0x573840031b42 - std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked::<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/thread/lifecycle.rs:68:26
[INFO] [stdout]   42:     0x573840031b42 - <std[ec419fa8110287d5]::thread::lifecycle::spawn_unchecked<test[a8007afcd3effadc]::run_test::{closure#1}, ()>::{closure#1} as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   43:     0x57384009a7bf - <alloc[a8a7aba520129d98]::boxed::Box<dyn core[35159d6ffb30e017]::ops::function::FnOnce<(), Output = ()> + core[35159d6ffb30e017]::marker::Send> as core[35159d6ffb30e017]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/alloc/src/boxed.rs:2271:9
[INFO] [stdout]   44:     0x57384009a7bf - <std[ec419fa8110287d5]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/33835004928d3bf65db4d4712e1330766263b0bd/library/std/src/sys/thread/unix.rs:118:17
[INFO] [stdout]   45:     0x7e73c58c2aa4 - <unknown>
[INFO] [stdout]   46:     0x7e73c594fa64 - clone
[INFO] [stdout]   47:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     dev::cart::header::test::test
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 0 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `-p gameboy-core --lib`
[INFO] running `Command { std: "docker" "inspect" "7a7a54dd0440a13efb8273533fd5155108be22d9fdd2bb2434081c6377170a25", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7a7a54dd0440a13efb8273533fd5155108be22d9fdd2bb2434081c6377170a25", kill_on_drop: false }`
[INFO] [stdout] 7a7a54dd0440a13efb8273533fd5155108be22d9fdd2bb2434081c6377170a25
