[INFO] cloning repository https://github.com/and00h/ohBoi-rs [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/and00h/ohBoi-rs" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fand00h%2FohBoi-rs", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fand00h%2FohBoi-rs'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 1382b3f1ba881959afdd520de8f36dfd2c035009 [INFO] checking and00h/ohBoi-rs/1382b3f1ba881959afdd520de8f36dfd2c035009 against master#ab869e094a907cc5d19b4080f22eccaf347f1f95 for pr-129604 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fand00h%2FohBoi-rs" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/and00h/ohBoi-rs on toolchain ab869e094a907cc5d19b4080f22eccaf347f1f95 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/and00h/ohBoi-rs [INFO] finished tweaking git repo https://github.com/and00h/ohBoi-rs [INFO] tweaked toml for git repo https://github.com/and00h/ohBoi-rs written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] crate git repo https://github.com/and00h/ohBoi-rs 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" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded imgui-sdl2-support v0.11.0 [INFO] [stderr] Downloaded chlorine v1.0.10 [INFO] [stderr] Downloaded openal-sys v1.16.0 [INFO] [stderr] Downloaded openal v0.2.2 [INFO] [stderr] Downloaded imgui-glow-renderer v0.11.0 [INFO] [stderr] Downloaded imgui v0.11.0 [INFO] [stderr] Downloaded imgui-sys v0.11.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 612b3305c00fa0b56c416d91fef5062fc260c398f33bce6c795c4e69b6685c15 [INFO] running `Command { std: "docker" "start" "-a" "612b3305c00fa0b56c416d91fef5062fc260c398f33bce6c795c4e69b6685c15", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "612b3305c00fa0b56c416d91fef5062fc260c398f33bce6c795c4e69b6685c15", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "612b3305c00fa0b56c416d91fef5062fc260c398f33bce6c795c4e69b6685c15", kill_on_drop: false }` [INFO] [stdout] 612b3305c00fa0b56c416d91fef5062fc260c398f33bce6c795c4e69b6685c15 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:923055f121b5182466d55868a8b05e67af8ba4a3a3f6bad814e953ca3cd3ac2a" "/opt/rustwide/cargo-home/bin/cargo" "+ab869e094a907cc5d19b4080f22eccaf347f1f95" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] cfa507815894085d7a35d0fbdc85a3de55a4882be225ee74bb6935d11010590a [INFO] running `Command { std: "docker" "start" "-a" "cfa507815894085d7a35d0fbdc85a3de55a4882be225ee74bb6935d11010590a", kill_on_drop: false }` [INFO] [stderr] Compiling autocfg v1.2.0 [INFO] [stderr] Compiling cc v1.0.95 [INFO] [stderr] Compiling proc-macro2 v1.0.81 [INFO] [stderr] Compiling version-compare v0.0.10 [INFO] [stderr] Compiling cfg-if v0.1.10 [INFO] [stderr] Compiling unicode-ident v1.0.12 [INFO] [stderr] Compiling parking_lot_core v0.9.10 [INFO] [stderr] Checking scopeguard v1.2.0 [INFO] [stderr] Checking smallvec v1.13.2 [INFO] [stderr] Checking chlorine v1.0.10 [INFO] [stderr] Checking mint v0.5.9 [INFO] [stderr] Checking utf8parse v0.2.1 [INFO] [stderr] Compiling sdl2 v0.34.5 [INFO] [stderr] Compiling sdl2-sys v0.34.5 [INFO] [stderr] Checking anstyle-parse v0.2.3 [INFO] [stderr] Checking anstyle-query v1.0.2 [INFO] [stderr] Checking memchr v2.7.2 [INFO] [stderr] Compiling serde v1.0.199 [INFO] [stderr] Checking colorchoice v1.0.0 [INFO] [stderr] Checking anstyle v1.0.6 [INFO] [stderr] Compiling lock_api v0.4.12 [INFO] [stderr] Compiling memoffset v0.6.5 [INFO] [stderr] Checking is-terminal v0.4.12 [INFO] [stderr] Compiling quote v1.0.36 [INFO] [stderr] Checking anstream v0.6.13 [INFO] [stderr] Checking clap_lex v0.7.0 [INFO] [stderr] Checking parking_lot v0.12.2 [INFO] [stderr] Compiling syn v2.0.60 [INFO] [stderr] Checking strsim v0.11.1 [INFO] [stderr] Checking regex-syntax v0.8.3 [INFO] [stderr] Compiling serde_json v1.0.116 [INFO] [stderr] Checking colored v1.9.4 [INFO] [stderr] Checking clap_builder v4.5.2 [INFO] [stderr] Checking openal-sys v1.16.0 [INFO] [stderr] Checking aho-corasick v1.1.3 [INFO] [stderr] Checking glow v0.12.3 [INFO] [stderr] Checking log v0.4.21 [INFO] [stderr] Checking itoa v1.0.11 [INFO] [stderr] Checking ryu v1.0.17 [INFO] [stderr] Checking fern v0.6.2 [INFO] [stderr] Checking openal v0.2.2 [INFO] [stderr] Compiling imgui-sys v0.11.0 [INFO] [stderr] Compiling tinyfiledialogs v3.9.1 [INFO] [stderr] Checking bitfield v0.15.0 [INFO] [stderr] Checking once_cell v1.19.0 [INFO] [stderr] Checking glow v0.13.1 [INFO] [stderr] Checking regex-automata v0.4.6 [INFO] [stderr] Compiling serde_derive v1.0.199 [INFO] [stderr] Checking clap v4.5.4 [INFO] [stderr] Checking regex v1.10.4 [INFO] [stderr] Checking imgui v0.11.0 [INFO] [stderr] Checking imgui-sdl2-support v0.11.0 [INFO] [stderr] Checking imgui-glow-renderer v0.11.0 [INFO] [stderr] Checking ohBoi-rs v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `WithFgColor` [INFO] [stdout] --> src/logging.rs:2:47 [INFO] [stdout] | [INFO] [stdout] 2 | use fern::colors::{Color, ColoredLevelConfig, WithFgColor}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RegexBuilder` and `Regex` [INFO] [stdout] --> src/logging.rs:3:13 [INFO] [stdout] | [INFO] [stdout] 3 | use regex::{Regex, RegexBuilder}; [INFO] [stdout] | ^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::core::utils::Counter` [INFO] [stdout] --> src/core/mod.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::core::utils::Counter; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/core/traits.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Weak` [INFO] [stdout] --> src/core/joypad.rs:3:19 [INFO] [stdout] | [INFO] [stdout] 3 | use std::rc::{Rc, Weak}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize` [INFO] [stdout] --> src/core/joypad.rs:5:13 [INFO] [stdout] | [INFO] [stdout] 5 | use serde::{Serialize, Deserialize}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Interrupt` [INFO] [stdout] --> src/core/bus.rs:8:31 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::core::interrupts::{Interrupt, InterruptController}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DmaState` [INFO] [stdout] --> src/core/bus.rs:12:47 [INFO] [stdout] | [INFO] [stdout] 12 | use crate::core::memory::dma::{DmaController, DmaState}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/core/cpu/instructions.rs:1:18 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{debug, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `NoArgs`, `OneArg`, and `TwoArgs` [INFO] [stdout] --> src/core/cpu/instructions.rs:17:23 [INFO] [stdout] | [INFO] [stdout] 17 | use InstructionType::{NoArgs, OneArg, TwoArgs}; [INFO] [stdout] | ^^^^^^ ^^^^^^ ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Register::*` [INFO] [stdout] --> src/core/cpu/prefixed_insts.rs:218:5 [INFO] [stdout] | [INFO] [stdout] 218 | use Register::*; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Ref` [INFO] [stdout] --> src/core/cpu/mod.rs:4:17 [INFO] [stdout] | [INFO] [stdout] 4 | use std::cell::{Ref, RefCell}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Weak` [INFO] [stdout] --> src/core/cpu/mod.rs:7:19 [INFO] [stdout] | [INFO] [stdout] 7 | use std::rc::{Rc, Weak}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `info` and `warn` [INFO] [stdout] --> src/core/cpu/mod.rs:8:18 [INFO] [stdout] | [INFO] [stdout] 8 | use log::{debug, info, trace, warn}; [INFO] [stdout] | ^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Bus` [INFO] [stdout] --> src/core/cpu/mod.rs:9:24 [INFO] [stdout] | [INFO] [stdout] 9 | use crate::core::bus::{Bus, BusController}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `InstructionType`, `MNEMONICS`, and `NARGS` [INFO] [stdout] --> src/core/cpu/mod.rs:51:61 [INFO] [stdout] | [INFO] [stdout] 51 | use crate::core::cpu::instructions::{InstArg, INSTRUCTIONS, InstructionType, MNEMONICS, NARGS}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ ^^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Cartridge` [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:2:38 [INFO] [stdout] | [INFO] [stdout] 2 | use crate::core::memory::cartridge::{Cartridge, CartridgeHeader, CartridgeType}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc1.rs:52:46 [INFO] [stdout] | [INFO] [stdout] 52 | 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 52 - 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] 52 + 0..=0x1FFF => self.ram_enabled = val & 0xF == 0xA, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `info` and `warn` [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:1:18 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{debug, info, warn}; [INFO] [stdout] | ^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BankingMode` [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:3:43 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::core::memory::cartridge::mbc::{BankingMode, RAM_BANK_SIZE, ROM_BANK_SIZE}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:52:46 [INFO] [stdout] | [INFO] [stdout] 52 | 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 52 - 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] 52 + 0..=0x1FFF => self.ram_enabled = val & 0xF == 0xA, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cell::RefCell` [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::cell::RefCell; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `IndexMut` [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:7:23 [INFO] [stdout] | [INFO] [stdout] 7 | use std::ops::{Index, IndexMut}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::rc::Rc` [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::rc::Rc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC1_RAM` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | MBC1_RAM = 0x02, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to upper camel case: `Mbc1Ram` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC1_RAM_BATTERY` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | MBC1_RAM_BATTERY = 0x03, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `Mbc1RamBattery` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC5_RAM` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | MBC5_RAM = 0x1A, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to upper camel case: `Mbc5Ram` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC5_RAM_BATTERY` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | MBC5_RAM_BATTERY = 0x1B [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `Mbc5RamBattery` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `ohBoi` should have an upper camel case name [INFO] [stdout] --> src/ohboi.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | pub struct ohBoi; [INFO] [stdout] | ^^^^^ help: convert the identifier to upper camel case (notice the capitalization): `OhBoi` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `fern::Output` [INFO] [stdout] --> src/ui/mod.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use fern::Output; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs::File` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::fs::File; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/main.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `WithFgColor` [INFO] [stdout] --> src/logging.rs:2:47 [INFO] [stdout] | [INFO] [stdout] 2 | use fern::colors::{Color, ColoredLevelConfig, WithFgColor}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `RegexBuilder` and `Regex` [INFO] [stdout] --> src/logging.rs:3:13 [INFO] [stdout] | [INFO] [stdout] 3 | use regex::{Regex, RegexBuilder}; [INFO] [stdout] | ^^^^^ ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::core::utils::Counter` [INFO] [stdout] --> src/core/mod.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::core::utils::Counter; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ops::Index` [INFO] [stdout] --> src/core/traits.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::ops::Index; [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Weak` [INFO] [stdout] --> src/core/joypad.rs:3:19 [INFO] [stdout] | [INFO] [stdout] 3 | use std::rc::{Rc, Weak}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize` [INFO] [stdout] --> src/core/joypad.rs:5:13 [INFO] [stdout] | [INFO] [stdout] 5 | use serde::{Serialize, Deserialize}; [INFO] [stdout] | ^^^^^^^^^ ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Interrupt` [INFO] [stdout] --> src/core/bus.rs:8:31 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::core::interrupts::{Interrupt, InterruptController}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `DmaState` [INFO] [stdout] --> src/core/bus.rs:12:47 [INFO] [stdout] | [INFO] [stdout] 12 | use crate::core::memory::dma::{DmaController, DmaState}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `warn` [INFO] [stdout] --> src/core/cpu/instructions.rs:1:18 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{debug, warn}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `NoArgs`, `OneArg`, and `TwoArgs` [INFO] [stdout] --> src/core/cpu/instructions.rs:17:23 [INFO] [stdout] | [INFO] [stdout] 17 | use InstructionType::{NoArgs, OneArg, TwoArgs}; [INFO] [stdout] | ^^^^^^ ^^^^^^ ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Register::*` [INFO] [stdout] --> src/core/cpu/prefixed_insts.rs:218:5 [INFO] [stdout] | [INFO] [stdout] 218 | use Register::*; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Ref` [INFO] [stdout] --> src/core/cpu/mod.rs:4:17 [INFO] [stdout] | [INFO] [stdout] 4 | use std::cell::{Ref, RefCell}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Weak` [INFO] [stdout] --> src/core/cpu/mod.rs:7:19 [INFO] [stdout] | [INFO] [stdout] 7 | use std::rc::{Rc, Weak}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `info` and `warn` [INFO] [stdout] --> src/core/cpu/mod.rs:8:18 [INFO] [stdout] | [INFO] [stdout] 8 | use log::{debug, info, trace, warn}; [INFO] [stdout] | ^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Bus` [INFO] [stdout] --> src/core/cpu/mod.rs:9:24 [INFO] [stdout] | [INFO] [stdout] 9 | use crate::core::bus::{Bus, BusController}; [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `InstructionType`, `MNEMONICS`, and `NARGS` [INFO] [stdout] --> src/core/cpu/mod.rs:51:61 [INFO] [stdout] | [INFO] [stdout] 51 | use crate::core::cpu::instructions::{InstArg, INSTRUCTIONS, InstructionType, MNEMONICS, NARGS}; [INFO] [stdout] | ^^^^^^^^^^^^^^^ ^^^^^^^^^ ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Cartridge` [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:2:38 [INFO] [stdout] | [INFO] [stdout] 2 | use crate::core::memory::cartridge::{Cartridge, CartridgeHeader, CartridgeType}; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc1.rs:52:46 [INFO] [stdout] | [INFO] [stdout] 52 | 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 52 - 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] 52 + 0..=0x1FFF => self.ram_enabled = val & 0xF == 0xA, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `info` and `warn` [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:1:18 [INFO] [stdout] | [INFO] [stdout] 1 | use log::{debug, info, warn}; [INFO] [stdout] | ^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BankingMode` [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:3:43 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::core::memory::cartridge::mbc::{BankingMode, RAM_BANK_SIZE, ROM_BANK_SIZE}; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around assigned value [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:52:46 [INFO] [stdout] | [INFO] [stdout] 52 | 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 52 - 0..=0x1FFF => self.ram_enabled = (val & 0xF == 0xA), [INFO] [stdout] 52 + 0..=0x1FFF => self.ram_enabled = val & 0xF == 0xA, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cell::RefCell` [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::cell::RefCell; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `IndexMut` [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:7:23 [INFO] [stdout] | [INFO] [stdout] 7 | use std::ops::{Index, IndexMut}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::rc::Rc` [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::rc::Rc; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC1_RAM` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:17:5 [INFO] [stdout] | [INFO] [stdout] 17 | MBC1_RAM = 0x02, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to upper camel case: `Mbc1Ram` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC1_RAM_BATTERY` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | MBC1_RAM_BATTERY = 0x03, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `Mbc1RamBattery` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC5_RAM` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:20:5 [INFO] [stdout] | [INFO] [stdout] 20 | MBC5_RAM = 0x1A, [INFO] [stdout] | ^^^^^^^^ help: convert the identifier to upper camel case: `Mbc5Ram` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `MBC5_RAM_BATTERY` should have an upper camel case name [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:21:5 [INFO] [stdout] | [INFO] [stdout] 21 | MBC5_RAM_BATTERY = 0x1B [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: convert the identifier to upper camel case: `Mbc5RamBattery` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type `ohBoi` should have an upper camel case name [INFO] [stdout] --> src/ohboi.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | pub struct ohBoi; [INFO] [stdout] | ^^^^^ help: convert the identifier to upper camel case (notice the capitalization): `OhBoi` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `fern::Output` [INFO] [stdout] --> src/ui/mod.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use fern::Output; [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::fs::File` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::fs::File; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/main.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> src/core/joypad.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/joypad.rs:84:13 [INFO] [stdout] | [INFO] [stdout] 84 | _ => {} [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/joypad.rs:84:13 [INFO] [stdout] | [INFO] [stdout] 76 | Key::A | Key::B | Key::Select | Key::Start => { [INFO] [stdout] | ------------------------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 80 | Key::Up | Key::Down | Key::Left | Key::Right => { [INFO] [stdout] | -------------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 84 | _ => {} [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/joypad.rs:97:13 [INFO] [stdout] | [INFO] [stdout] 97 | _ => {} [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/joypad.rs:97:13 [INFO] [stdout] | [INFO] [stdout] 91 | Key::A | Key::B | Key::Select | Key::Start => { [INFO] [stdout] | ------------------------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 94 | Key::Up | Key::Down | Key::Left | Key::Right => { [INFO] [stdout] | -------------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 97 | _ => {} [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:154:17 [INFO] [stdout] | [INFO] [stdout] 154 | _ => unreachable!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:154:17 [INFO] [stdout] | [INFO] [stdout] 146 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow().read(addr), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 147 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow().read(addr, false), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 148 | 0xC000..=0xDFFF => self.wram.read(addr), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 149 | 0xE000..=0xFDFF => self.wram.read(addr - 0x2000), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 154 | _ => unreachable!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:172:17 [INFO] [stdout] | [INFO] [stdout] 172 | _ => unimplemented!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:172:17 [INFO] [stdout] | [INFO] [stdout] 164 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow_mut().write(addr, val), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 165 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow_mut().write(addr, val, false), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 166 | 0xC000..=0xDFFF => self.wram.write(addr, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 167 | 0xE000..=0xFDFF => self.wram.write(addr - 0x2000, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 172 | _ => unimplemented!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:187:13 [INFO] [stdout] | [INFO] [stdout] 187 | _ => unimplemented!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:187:13 [INFO] [stdout] | [INFO] [stdout] 179 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow_mut().read(addr, true), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 180 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow().read(addr), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 181 | 0xC000..=0xDFFF => self.wram.read(addr), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 182 | 0xE000..=0xFDFF => self.wram.read(addr - 0x2000), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 187 | _ => unimplemented!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:201:13 [INFO] [stdout] | [INFO] [stdout] 201 | _ => unimplemented!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:201:13 [INFO] [stdout] | [INFO] [stdout] 193 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow_mut().write(addr, val, true), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 194 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow_mut().write(addr, val), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 195 | 0xC000..=0xDFFF => self.wram.write(addr, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 196 | 0xE000..=0xFDFF => self.wram.write(addr - 0x2000, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 201 | _ => unimplemented!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/core/cpu/mod.rs:482:25 [INFO] [stdout] | [INFO] [stdout] 482 | let mut data = self.bus.read(addr).wrapping_sub(1); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `condition` [INFO] [stdout] --> src/core/cpu/mod.rs:971:23 [INFO] [stdout] | [INFO] [stdout] 971 | fn ret(&mut self, condition: bool) { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_condition` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `reg` [INFO] [stdout] --> src/core/cpu/mod.rs:1301:33 [INFO] [stdout] | [INFO] [stdout] 1301 | fn load_indirect(&mut self, reg: Register8, src: Register16) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_reg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | t => { [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 49 | CartridgeType::None => Box::new(none::None::new(rom)), [INFO] [stdout] | ------------------- matches some of the same values [INFO] [stdout] 50 | CartridgeType::MBC1 => [INFO] [stdout] | ------------------- matches some of the same values [INFO] [stdout] 51 | Box::new(mbc1::Mbc1::new(rom, header, None, false)), [INFO] [stdout] 52 | CartridgeType::MBC1_RAM => [INFO] [stdout] | ----------------------- matches some of the same values [INFO] [stdout] 53 | Box::new(mbc1::Mbc1::new(rom, header, ram, false)), [INFO] [stdout] 54 | CartridgeType::MBC1_RAM_BATTERY => Box::new(mbc1::Mbc1::new(rom, header, ram, true)), [INFO] [stdout] | ------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 60 | t => { [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::borrow::BorrowMut` [INFO] [stdout] --> src/core/joypad.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use std::borrow::BorrowMut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `log_buffer` [INFO] [stdout] --> src/ui/mod.rs:118:16 [INFO] [stdout] | [INFO] [stdout] 118 | pub fn new(log_buffer: Option>>>) [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_buffer` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/joypad.rs:84:13 [INFO] [stdout] | [INFO] [stdout] 84 | _ => {} [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/joypad.rs:84:13 [INFO] [stdout] | [INFO] [stdout] 76 | Key::A | Key::B | Key::Select | Key::Start => { [INFO] [stdout] | ------------------------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 80 | Key::Up | Key::Down | Key::Left | Key::Right => { [INFO] [stdout] | -------------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 84 | _ => {} [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] = note: `#[warn(unreachable_patterns)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/joypad.rs:97:13 [INFO] [stdout] | [INFO] [stdout] 97 | _ => {} [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/joypad.rs:97:13 [INFO] [stdout] | [INFO] [stdout] 91 | Key::A | Key::B | Key::Select | Key::Start => { [INFO] [stdout] | ------------------------------------------ matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 94 | Key::Up | Key::Down | Key::Left | Key::Right => { [INFO] [stdout] | -------------------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 97 | _ => {} [INFO] [stdout] | ^ collectively making this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `sample` [INFO] [stdout] --> src/ui/mod.rs:219:68 [INFO] [stdout] | [INFO] [stdout] 219 | ...meBoy, text: Option, sample: (&[f32], &[f32], &[f32], &[f32])) -> Result> { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_sample` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `fps` is assigned to, but never used [INFO] [stdout] --> src/main.rs:34:17 [INFO] [stdout] | [INFO] [stdout] 34 | let mut fps = String::from("0.0"); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_fps` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `fps` is never read [INFO] [stdout] --> src/main.rs:76:9 [INFO] [stdout] | [INFO] [stdout] 76 | fps = format!("FPS: {}", 1.0 / elapsed.as_secs_f64()); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:154:17 [INFO] [stdout] | [INFO] [stdout] 154 | _ => unreachable!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:154:17 [INFO] [stdout] | [INFO] [stdout] 146 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow().read(addr), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 147 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow().read(addr, false), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 148 | 0xC000..=0xDFFF => self.wram.read(addr), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 149 | 0xE000..=0xFDFF => self.wram.read(addr - 0x2000), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 154 | _ => unreachable!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:172:17 [INFO] [stdout] | [INFO] [stdout] 172 | _ => unimplemented!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:172:17 [INFO] [stdout] | [INFO] [stdout] 164 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow_mut().write(addr, val), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 165 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow_mut().write(addr, val, false), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 166 | 0xC000..=0xDFFF => self.wram.write(addr, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 167 | 0xE000..=0xFDFF => self.wram.write(addr - 0x2000, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 172 | _ => unimplemented!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:187:13 [INFO] [stdout] | [INFO] [stdout] 187 | _ => unimplemented!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:187:13 [INFO] [stdout] | [INFO] [stdout] 179 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow_mut().read(addr, true), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 180 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow().read(addr), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 181 | 0xC000..=0xDFFF => self.wram.read(addr), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 182 | 0xE000..=0xFDFF => self.wram.read(addr - 0x2000), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 187 | _ => unimplemented!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:36:13 [INFO] [stdout] | [INFO] [stdout] 36 | let mut speed = 1; [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/bus.rs:201:13 [INFO] [stdout] | [INFO] [stdout] 201 | _ => unimplemented!() [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/bus.rs:201:13 [INFO] [stdout] | [INFO] [stdout] 193 | 0x8000..=0x9FFF | 0xFE00..=0xFE9F => (*self.ppu).borrow_mut().write(addr, val, true), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 194 | 0x0000..=0x7FFF | 0xA000..=0xBFFF => (*self.cartridge).borrow_mut().write(addr, val), [INFO] [stdout] | --------------------------------- matches some of the same values [INFO] [stdout] 195 | 0xC000..=0xDFFF => self.wram.write(addr, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] 196 | 0xE000..=0xFDFF => self.wram.write(addr - 0x2000, val), [INFO] [stdout] | --------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 201 | _ => unimplemented!() [INFO] [stdout] | ^ ...and 4 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `text` and `level` are never read [INFO] [stdout] --> src/logging.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct ImguiLogString { [INFO] [stdout] | -------------- fields in this struct [INFO] [stdout] 6 | pub text: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 7 | pub level: log::Level [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `enable_audio_channels` is never read [INFO] [stdout] --> src/core/mod.rs:37:5 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct GameBoy { [INFO] [stdout] | ------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 37 | enable_audio_channels: (bool, bool, bool, bool) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `AddressSpace` is never used [INFO] [stdout] --> src/core/traits.rs:3:7 [INFO] [stdout] | [INFO] [stdout] 3 | trait AddressSpace { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `Clock` is never used [INFO] [stdout] --> src/core/traits.rs:8:7 [INFO] [stdout] | [INFO] [stdout] 8 | trait Clock { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `is_pressed`, `keys_enabled`, and `keys_pressed` are never used [INFO] [stdout] --> src/core/joypad.rs:101:18 [INFO] [stdout] | [INFO] [stdout] 45 | impl Joypad { [INFO] [stdout] | ----------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 101 | pub(self) fn is_pressed(&self, key: Key) -> bool { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 118 | fn keys_enabled(&self) -> bool { (self.key_state_buttons & key_masks::KEY_GROUPS) != key_masks::KEY_GROUPS } [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 119 | #[inline] [INFO] [stdout] 120 | fn keys_pressed(&self) -> bool { (self.key_state_buttons & key_masks::KEYS) != key_masks::KEYS } [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `KEYS` is never used [INFO] [stdout] --> src/core/joypad.rs:17:15 [INFO] [stdout] | [INFO] [stdout] 17 | pub const KEYS: u8 = RIGHT_A | LEFT_B | UP_SELECT | DOWN_START; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `cgb` is never read [INFO] [stdout] --> src/core/cpu/mod.rs:46:5 [INFO] [stdout] | [INFO] [stdout] 44 | pub(crate) struct Registers { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] 45 | regs: Vec, [INFO] [stdout] 46 | cgb: bool [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `reset` is never used [INFO] [stdout] --> src/core/cpu/mod.rs:65:12 [INFO] [stdout] | [INFO] [stdout] 54 | impl Registers { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 65 | pub fn reset(&mut self) { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `ALU16ReadHi` is never constructed [INFO] [stdout] --> src/core/cpu/mod.rs:165:5 [INFO] [stdout] | [INFO] [stdout] 156 | pub(crate) enum CpuState { [INFO] [stdout] | -------- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 165 | ALU16ReadHi, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `CpuState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `cgb` is never read [INFO] [stdout] --> src/core/cpu/mod.rs:218:5 [INFO] [stdout] | [INFO] [stdout] 201 | pub(crate) struct Cpu { [INFO] [stdout] | --- field in this struct [INFO] [stdout] ... [INFO] [stdout] 218 | cgb: bool, [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `store_hl_immediate` is never used [INFO] [stdout] --> src/core/cpu/mod.rs:496:8 [INFO] [stdout] | [INFO] [stdout] 221 | impl Cpu { [INFO] [stdout] | -------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 496 | fn store_hl_immediate(&mut self) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `NoArgOp` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:7:6 [INFO] [stdout] | [INFO] [stdout] 7 | type NoArgOp = fn(&mut Cpu); [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `OneArgOp` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:8:6 [INFO] [stdout] | [INFO] [stdout] 8 | type OneArgOp = fn(&mut Cpu, u8); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `TwoArgOp` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:9:6 [INFO] [stdout] | [INFO] [stdout] 9 | type TwoArgOp = fn(&mut Cpu, u16); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `InstructionType` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:11:17 [INFO] [stdout] | [INFO] [stdout] 11 | pub(super) enum InstructionType { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static `NARGS` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub static NARGS: [usize; 256] = [ [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static `MNEMONICS` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:280:12 [INFO] [stdout] | [INFO] [stdout] 280 | pub static MNEMONICS: [&'static str; 256] = [ [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `hi` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:569:12 [INFO] [stdout] | [INFO] [stdout] 549 | impl InstArg { [INFO] [stdout] | ------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 569 | pub fn hi(&self) -> u8 { [INFO] [stdout] | ^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Inst` is never constructed [INFO] [stdout] --> src/core/cpu/instructions.rs:581:8 [INFO] [stdout] | [INFO] [stdout] 581 | struct Inst { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `advance` are never used [INFO] [stdout] --> src/core/cpu/instructions.rs:587:12 [INFO] [stdout] | [INFO] [stdout] 586 | impl Inst { [INFO] [stdout] | -------------------------------- associated items in this implementation [INFO] [stdout] 587 | pub fn new(inst_type: InstructionType, transition_func: F) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 594 | pub fn advance(&mut self, cpu: &mut Cpu) { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `Register` is never used [INFO] [stdout] --> src/core/cpu/prefixed_insts.rs:7:6 [INFO] [stdout] | [INFO] [stdout] 7 | enum Register { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `switch_bank` is never used [INFO] [stdout] --> src/core/memory/mod.rs:37:12 [INFO] [stdout] | [INFO] [stdout] 11 | impl WRAM { [INFO] [stdout] | --------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 37 | pub fn switch_bank(&mut self, new_bank: usize) { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `state` is never used [INFO] [stdout] --> src/core/memory/dma.rs:53:12 [INFO] [stdout] | [INFO] [stdout] 24 | impl DmaController { [INFO] [stdout] | ------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 53 | pub fn state(&self) -> DmaState { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:43:5 [INFO] [stdout] | [INFO] [stdout] 42 | struct CartridgeHeader { [INFO] [stdout] | --------------- fields in this struct [INFO] [stdout] 43 | entry_point: Vec, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 44 | logo: Vec, [INFO] [stdout] | ^^^^ [INFO] [stdout] 45 | title: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 46 | manufacturer_code: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 47 | cgb: bool, [INFO] [stdout] 48 | new_licensee_code: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 49 | sgb: bool, [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 53 | dest_code: u8, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 54 | old_licensee_code: u8, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 55 | version: u8, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 56 | header_checksum: u8, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] 57 | global_checksum: Vec [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `rom_path` is never read [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:108:5 [INFO] [stdout] | [INFO] [stdout] 107 | pub struct Cartridge { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] 108 | rom_path: PathBuf, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `RAM_SIZE_MAP` is never used [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:13:7 [INFO] [stdout] | [INFO] [stdout] 13 | const RAM_SIZE_MAP: [usize; 6] = [ [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calc_rom_size` is never used [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:20:4 [INFO] [stdout] | [INFO] [stdout] 20 | fn calc_rom_size(header_rom_size: usize) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `num_banks`, `num_ram_banks`, and `has_rtc` are never used [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:36:8 [INFO] [stdout] | [INFO] [stdout] 30 | pub(crate) trait Mbc { [INFO] [stdout] | --- methods in this trait [INFO] [stdout] ... [INFO] [stdout] 36 | fn num_banks(&self) -> usize { 2 } [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 37 | fn num_ram_banks(&self) -> usize { 0 } [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 40 | fn has_rtc(&self) -> bool { false } [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `n_ram_banks` is never read [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 6 | pub(super) struct Mbc5 { [INFO] [stdout] | ---- field in this struct [INFO] [stdout] ... [INFO] [stdout] 15 | n_ram_banks: usize [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/core/gpu.rs:64:12 [INFO] [stdout] | [INFO] [stdout] 63 | impl Tile { [INFO] [stdout] | --------- associated function in this implementation [INFO] [stdout] 64 | pub fn new(data: &[u8]) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `oam_offset` is never read [INFO] [stdout] --> src/core/gpu.rs:103:5 [INFO] [stdout] | [INFO] [stdout] 101 | struct SpritePixel { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] 102 | pixel: TilePixel, [INFO] [stdout] 103 | oam_offset: u8 [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `cgb_palette_number` and `vram_bank` are never used [INFO] [stdout] --> src/core/gpu.rs:128:12 [INFO] [stdout] | [INFO] [stdout] 116 | impl Sprite { [INFO] [stdout] | ----------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 128 | pub fn cgb_palette_number(&self) -> u8 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 137 | pub fn vram_bank(&self) -> u8 { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `value` is never used [INFO] [stdout] --> src/core/gpu.rs:378:12 [INFO] [stdout] | [INFO] [stdout] 352 | impl DmgPalette { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 378 | pub fn value(&self) -> u8 { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `MODE` is never used [INFO] [stdout] --> src/core/gpu.rs:39:15 [INFO] [stdout] | [INFO] [stdout] 39 | pub const MODE: u8 = 0b00000011; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `LY_COMPARE_INTERRUPT` is never used [INFO] [stdout] --> src/core/gpu.rs:44:15 [INFO] [stdout] | [INFO] [stdout] 44 | pub const LY_COMPARE_INTERRUPT: u8 = 0b01000000; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `CGB_PALETTE_NUMBER` is never used [INFO] [stdout] --> src/core/gpu.rs:49:15 [INFO] [stdout] | [INFO] [stdout] 49 | pub const CGB_PALETTE_NUMBER: u8 = 0b00000111; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `VRAM_BANK` is never used [INFO] [stdout] --> src/core/gpu.rs:50:15 [INFO] [stdout] | [INFO] [stdout] 50 | pub const VRAM_BANK: u8 = 0b00001000; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `volume` and `dac_enabled` are never read [INFO] [stdout] --> src/core/audio/channels.rs:438:5 [INFO] [stdout] | [INFO] [stdout] 429 | pub struct WaveChannel { [INFO] [stdout] | ----------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 438 | volume: u8, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 441 | dac_enabled: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ohBoi` is never constructed [INFO] [stdout] --> src/ohboi.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | pub struct ohBoi; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/ohboi.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 3 | impl ohBoi { [INFO] [stdout] | ---------- associated function in this implementation [INFO] [stdout] 4 | pub fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `gl_context` is never read [INFO] [stdout] --> src/ui/mod.rs:99:5 [INFO] [stdout] | [INFO] [stdout] 96 | pub struct OhBoiUi { [INFO] [stdout] | ------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 99 | gl_context: GLContext, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/core/cpu/mod.rs:482:25 [INFO] [stdout] | [INFO] [stdout] 482 | let mut data = self.bus.read(addr).wrapping_sub(1); [INFO] [stdout] | ----^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `condition` [INFO] [stdout] --> src/core/cpu/mod.rs:971:23 [INFO] [stdout] | [INFO] [stdout] 971 | fn ret(&mut self, condition: bool) { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_condition` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `reg` [INFO] [stdout] --> src/core/cpu/mod.rs:1301:33 [INFO] [stdout] | [INFO] [stdout] 1301 | fn load_indirect(&mut self, reg: Register8, src: Register16) { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_reg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unreachable pattern [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | t => { [INFO] [stdout] | ^ no value can reach this [INFO] [stdout] | [INFO] [stdout] note: multiple earlier patterns match some of the same values [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 49 | CartridgeType::None => Box::new(none::None::new(rom)), [INFO] [stdout] | ------------------- matches some of the same values [INFO] [stdout] 50 | CartridgeType::MBC1 => [INFO] [stdout] | ------------------- matches some of the same values [INFO] [stdout] 51 | Box::new(mbc1::Mbc1::new(rom, header, None, false)), [INFO] [stdout] 52 | CartridgeType::MBC1_RAM => [INFO] [stdout] | ----------------------- matches some of the same values [INFO] [stdout] 53 | Box::new(mbc1::Mbc1::new(rom, header, ram, false)), [INFO] [stdout] 54 | CartridgeType::MBC1_RAM_BATTERY => Box::new(mbc1::Mbc1::new(rom, header, ram, true)), [INFO] [stdout] | ------------------------------- matches some of the same values [INFO] [stdout] ... [INFO] [stdout] 60 | t => { [INFO] [stdout] | ^ ...and 3 other patterns collectively make this unreachable [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 89 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `log_buffer` [INFO] [stdout] --> src/ui/mod.rs:118:16 [INFO] [stdout] | [INFO] [stdout] 118 | pub fn new(log_buffer: Option>>>) [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_log_buffer` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `sample` [INFO] [stdout] --> src/ui/mod.rs:219:68 [INFO] [stdout] | [INFO] [stdout] 219 | ...meBoy, text: Option, sample: (&[f32], &[f32], &[f32], &[f32])) -> Result> { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_sample` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `fps` is assigned to, but never used [INFO] [stdout] --> src/main.rs:34:17 [INFO] [stdout] | [INFO] [stdout] 34 | let mut fps = String::from("0.0"); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_fps` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: value assigned to `fps` is never read [INFO] [stdout] --> src/main.rs:76:9 [INFO] [stdout] | [INFO] [stdout] 76 | fps = format!("FPS: {}", 1.0 / elapsed.as_secs_f64()); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = help: maybe it is overwritten before being read? [INFO] [stdout] = note: `#[warn(unused_assignments)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/main.rs:36:13 [INFO] [stdout] | [INFO] [stdout] 36 | let mut speed = 1; [INFO] [stdout] | ----^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `text` and `level` are never read [INFO] [stdout] --> src/logging.rs:6:9 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct ImguiLogString { [INFO] [stdout] | -------------- fields in this struct [INFO] [stdout] 6 | pub text: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 7 | pub level: log::Level [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `enable_audio_channels` is never read [INFO] [stdout] --> src/core/mod.rs:37:5 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct GameBoy { [INFO] [stdout] | ------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 37 | enable_audio_channels: (bool, bool, bool, bool) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `AddressSpace` is never used [INFO] [stdout] --> src/core/traits.rs:3:7 [INFO] [stdout] | [INFO] [stdout] 3 | trait AddressSpace { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait `Clock` is never used [INFO] [stdout] --> src/core/traits.rs:8:7 [INFO] [stdout] | [INFO] [stdout] 8 | trait Clock { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `keys_enabled` and `keys_pressed` are never used [INFO] [stdout] --> src/core/joypad.rs:118:8 [INFO] [stdout] | [INFO] [stdout] 45 | impl Joypad { [INFO] [stdout] | ----------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 118 | fn keys_enabled(&self) -> bool { (self.key_state_buttons & key_masks::KEY_GROUPS) != key_masks::KEY_GROUPS } [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] 119 | #[inline] [INFO] [stdout] 120 | fn keys_pressed(&self) -> bool { (self.key_state_buttons & key_masks::KEYS) != key_masks::KEYS } [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `KEYS` is never used [INFO] [stdout] --> src/core/joypad.rs:17:15 [INFO] [stdout] | [INFO] [stdout] 17 | pub const KEYS: u8 = RIGHT_A | LEFT_B | UP_SELECT | DOWN_START; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `cgb` is never read [INFO] [stdout] --> src/core/cpu/mod.rs:46:5 [INFO] [stdout] | [INFO] [stdout] 44 | pub(crate) struct Registers { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] 45 | regs: Vec, [INFO] [stdout] 46 | cgb: bool [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `reset` is never used [INFO] [stdout] --> src/core/cpu/mod.rs:65:12 [INFO] [stdout] | [INFO] [stdout] 54 | impl Registers { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 65 | pub fn reset(&mut self) { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variant `ALU16ReadHi` is never constructed [INFO] [stdout] --> src/core/cpu/mod.rs:165:5 [INFO] [stdout] | [INFO] [stdout] 156 | pub(crate) enum CpuState { [INFO] [stdout] | -------- variant in this enum [INFO] [stdout] ... [INFO] [stdout] 165 | ALU16ReadHi, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `CpuState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `cgb` is never read [INFO] [stdout] --> src/core/cpu/mod.rs:218:5 [INFO] [stdout] | [INFO] [stdout] 201 | pub(crate) struct Cpu { [INFO] [stdout] | --- field in this struct [INFO] [stdout] ... [INFO] [stdout] 218 | cgb: bool, [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `store_hl_immediate` is never used [INFO] [stdout] --> src/core/cpu/mod.rs:496:8 [INFO] [stdout] | [INFO] [stdout] 221 | impl Cpu { [INFO] [stdout] | -------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 496 | fn store_hl_immediate(&mut self) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `NoArgOp` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:7:6 [INFO] [stdout] | [INFO] [stdout] 7 | type NoArgOp = fn(&mut Cpu); [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `OneArgOp` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:8:6 [INFO] [stdout] | [INFO] [stdout] 8 | type OneArgOp = fn(&mut Cpu, u8); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `TwoArgOp` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:9:6 [INFO] [stdout] | [INFO] [stdout] 9 | type TwoArgOp = fn(&mut Cpu, u16); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `InstructionType` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:11:17 [INFO] [stdout] | [INFO] [stdout] 11 | pub(super) enum InstructionType { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static `NARGS` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub static NARGS: [usize; 256] = [ [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: static `MNEMONICS` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:280:12 [INFO] [stdout] | [INFO] [stdout] 280 | pub static MNEMONICS: [&'static str; 256] = [ [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `hi` is never used [INFO] [stdout] --> src/core/cpu/instructions.rs:569:12 [INFO] [stdout] | [INFO] [stdout] 549 | impl InstArg { [INFO] [stdout] | ------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 569 | pub fn hi(&self) -> u8 { [INFO] [stdout] | ^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Inst` is never constructed [INFO] [stdout] --> src/core/cpu/instructions.rs:581:8 [INFO] [stdout] | [INFO] [stdout] 581 | struct Inst { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `new` and `advance` are never used [INFO] [stdout] --> src/core/cpu/instructions.rs:587:12 [INFO] [stdout] | [INFO] [stdout] 586 | impl Inst { [INFO] [stdout] | -------------------------------- associated items in this implementation [INFO] [stdout] 587 | pub fn new(inst_type: InstructionType, transition_func: F) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 594 | pub fn advance(&mut self, cpu: &mut Cpu) { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `Register` is never used [INFO] [stdout] --> src/core/cpu/prefixed_insts.rs:7:6 [INFO] [stdout] | [INFO] [stdout] 7 | enum Register { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `switch_bank` is never used [INFO] [stdout] --> src/core/memory/mod.rs:37:12 [INFO] [stdout] | [INFO] [stdout] 11 | impl WRAM { [INFO] [stdout] | --------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 37 | pub fn switch_bank(&mut self, new_bank: usize) { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `state` is never used [INFO] [stdout] --> src/core/memory/dma.rs:53:12 [INFO] [stdout] | [INFO] [stdout] 24 | impl DmaController { [INFO] [stdout] | ------------------ method in this implementation [INFO] [stdout] ... [INFO] [stdout] 53 | pub fn state(&self) -> DmaState { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple fields are never read [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:43:5 [INFO] [stdout] | [INFO] [stdout] 42 | struct CartridgeHeader { [INFO] [stdout] | --------------- fields in this struct [INFO] [stdout] 43 | entry_point: Vec, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] 44 | logo: Vec, [INFO] [stdout] | ^^^^ [INFO] [stdout] 45 | title: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] 46 | manufacturer_code: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 47 | cgb: bool, [INFO] [stdout] 48 | new_licensee_code: String, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 49 | sgb: bool, [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 53 | dest_code: u8, [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 54 | old_licensee_code: u8, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] 55 | version: u8, [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] 56 | header_checksum: u8, [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] 57 | global_checksum: Vec [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `rom_path` is never read [INFO] [stdout] --> src/core/memory/cartridge/mod.rs:108:5 [INFO] [stdout] | [INFO] [stdout] 107 | pub struct Cartridge { [INFO] [stdout] | --------- field in this struct [INFO] [stdout] 108 | rom_path: PathBuf, [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `RAM_SIZE_MAP` is never used [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:13:7 [INFO] [stdout] | [INFO] [stdout] 13 | const RAM_SIZE_MAP: [usize; 6] = [ [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calc_rom_size` is never used [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:20:4 [INFO] [stdout] | [INFO] [stdout] 20 | fn calc_rom_size(header_rom_size: usize) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `num_banks`, `num_ram_banks`, and `has_rtc` are never used [INFO] [stdout] --> src/core/memory/cartridge/mbc/mod.rs:36:8 [INFO] [stdout] | [INFO] [stdout] 30 | pub(crate) trait Mbc { [INFO] [stdout] | --- methods in this trait [INFO] [stdout] ... [INFO] [stdout] 36 | fn num_banks(&self) -> usize { 2 } [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 37 | fn num_ram_banks(&self) -> usize { 0 } [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 40 | fn has_rtc(&self) -> bool { false } [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `n_ram_banks` is never read [INFO] [stdout] --> src/core/memory/cartridge/mbc/mbc5.rs:15:5 [INFO] [stdout] | [INFO] [stdout] 6 | pub(super) struct Mbc5 { [INFO] [stdout] | ---- field in this struct [INFO] [stdout] ... [INFO] [stdout] 15 | n_ram_banks: usize [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/core/gpu.rs:64:12 [INFO] [stdout] | [INFO] [stdout] 63 | impl Tile { [INFO] [stdout] | --------- associated function in this implementation [INFO] [stdout] 64 | pub fn new(data: &[u8]) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `oam_offset` is never read [INFO] [stdout] --> src/core/gpu.rs:103:5 [INFO] [stdout] | [INFO] [stdout] 101 | struct SpritePixel { [INFO] [stdout] | ----------- field in this struct [INFO] [stdout] 102 | pixel: TilePixel, [INFO] [stdout] 103 | oam_offset: u8 [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `cgb_palette_number` and `vram_bank` are never used [INFO] [stdout] --> src/core/gpu.rs:128:12 [INFO] [stdout] | [INFO] [stdout] 116 | impl Sprite { [INFO] [stdout] | ----------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 128 | pub fn cgb_palette_number(&self) -> u8 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 137 | pub fn vram_bank(&self) -> u8 { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `value` is never used [INFO] [stdout] --> src/core/gpu.rs:378:12 [INFO] [stdout] | [INFO] [stdout] 352 | impl DmgPalette { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 378 | pub fn value(&self) -> u8 { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `MODE` is never used [INFO] [stdout] --> src/core/gpu.rs:39:15 [INFO] [stdout] | [INFO] [stdout] 39 | pub const MODE: u8 = 0b00000011; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `LY_COMPARE_INTERRUPT` is never used [INFO] [stdout] --> src/core/gpu.rs:44:15 [INFO] [stdout] | [INFO] [stdout] 44 | pub const LY_COMPARE_INTERRUPT: u8 = 0b01000000; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `CGB_PALETTE_NUMBER` is never used [INFO] [stdout] --> src/core/gpu.rs:49:15 [INFO] [stdout] | [INFO] [stdout] 49 | pub const CGB_PALETTE_NUMBER: u8 = 0b00000111; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: constant `VRAM_BANK` is never used [INFO] [stdout] --> src/core/gpu.rs:50:15 [INFO] [stdout] | [INFO] [stdout] 50 | pub const VRAM_BANK: u8 = 0b00001000; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `volume` and `dac_enabled` are never read [INFO] [stdout] --> src/core/audio/channels.rs:438:5 [INFO] [stdout] | [INFO] [stdout] 429 | pub struct WaveChannel { [INFO] [stdout] | ----------- fields in this struct [INFO] [stdout] ... [INFO] [stdout] 438 | volume: u8, [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 441 | dac_enabled: bool, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ohBoi` is never constructed [INFO] [stdout] --> src/ohboi.rs:1:12 [INFO] [stdout] | [INFO] [stdout] 1 | pub struct ohBoi; [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/ohboi.rs:4:12 [INFO] [stdout] | [INFO] [stdout] 3 | impl ohBoi { [INFO] [stdout] | ---------- associated function in this implementation [INFO] [stdout] 4 | pub fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `gl_context` is never read [INFO] [stdout] --> src/ui/mod.rs:99:5 [INFO] [stdout] | [INFO] [stdout] 96 | pub struct OhBoiUi { [INFO] [stdout] | ------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 99 | gl_context: GLContext, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 89 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.52s [INFO] running `Command { std: "docker" "inspect" "cfa507815894085d7a35d0fbdc85a3de55a4882be225ee74bb6935d11010590a", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "cfa507815894085d7a35d0fbdc85a3de55a4882be225ee74bb6935d11010590a", kill_on_drop: false }` [INFO] [stdout] cfa507815894085d7a35d0fbdc85a3de55a4882be225ee74bb6935d11010590a