From 8148bdbbbed1e5048a2fbf42a454878ef927ea26 Mon Sep 17 00:00:00 2001 From: Denis Nutiu Date: Wed, 11 Dec 2024 00:33:45 +0200 Subject: [PATCH] use c-like struct for input keys instructions --- src/emulator.rs | 6 +++--- src/instruction.rs | 30 +++++++++++++++--------------- 2 files changed, 18 insertions(+), 18 deletions(-) diff --git a/src/emulator.rs b/src/emulator.rs index ab55053..2740aca 100644 --- a/src/emulator.rs +++ b/src/emulator.rs @@ -420,21 +420,21 @@ where self.memory[memory_index] = self.registers[i as usize]; } } - ProcessorInstruction::GetKeyBlocking(vx) => { + ProcessorInstruction::GetKeyBlocking { vx } => { if let Some(key) = self.last_key_pressed { self.registers[vx as usize] = key; } else { self.program_counter -= 2; } } - ProcessorInstruction::SkipIfKeyIsPressed(vx) => { + ProcessorInstruction::SkipIfKeyIsPressed { vx } => { if let Some(key) = self.last_key_pressed { if self.registers[vx as usize] == key { self.program_counter += 2; } } } - ProcessorInstruction::SkipIfKeyIsNotPressed(vx) => { + ProcessorInstruction::SkipIfKeyIsNotPressed { vx } => { if let Some(key) = self.last_key_pressed { if self.registers[vx as usize] != key { self.program_counter += 2; diff --git a/src/instruction.rs b/src/instruction.rs index a7aa2ce..a5ffa19 100644 --- a/src/instruction.rs +++ b/src/instruction.rs @@ -79,11 +79,11 @@ pub enum ProcessorInstruction { /// Loads the general purpose registers from memory at index register address. LoadMemory { vx: u8 }, /// Blocks execution and waits for input. If a key is pressed it will be put in VX. - GetKeyBlocking(u8), + GetKeyBlocking { vx: u8 }, /// Skips one instruction if a key value stored in VX is pressed. Doesn't block execution. - SkipIfKeyIsPressed(u8), + SkipIfKeyIsPressed { vx: u8 }, /// Skips one instruction if a key value stored in VX is NOT pressed. Doesn't block execution. - SkipIfKeyIsNotPressed(u8), + SkipIfKeyIsNotPressed { vx: u8 }, /// Unknown instruction UnknownInstruction, } @@ -245,15 +245,15 @@ impl Instruction { (0xF, _, 0x6, 0x5) => ProcessorInstruction::LoadMemory { vx: Self::grab_first_nibble(data), }, - (0xE, _, 0x9, 0xE) => { - ProcessorInstruction::SkipIfKeyIsPressed(Self::grab_first_nibble(data)) - } - (0xE, _, 0xA, 0x1) => { - ProcessorInstruction::SkipIfKeyIsNotPressed(Self::grab_first_nibble(data)) - } - (0xF, _, 0x0, 0xA) => { - ProcessorInstruction::GetKeyBlocking(Self::grab_first_nibble(data)) - } + (0xE, _, 0x9, 0xE) => ProcessorInstruction::SkipIfKeyIsPressed { + vx: Self::grab_first_nibble(data), + }, + (0xE, _, 0xA, 0x1) => ProcessorInstruction::SkipIfKeyIsNotPressed { + vx: Self::grab_first_nibble(data), + }, + (0xF, _, 0x0, 0xA) => ProcessorInstruction::GetKeyBlocking { + vx: Self::grab_first_nibble(data), + }, // Unknown instruction _ => ProcessorInstruction::UnknownInstruction, } @@ -633,7 +633,7 @@ mod tests { let instruction = Instruction::new([0xEF, 0x9E]); assert_eq!( instruction.processor_instruction, - ProcessorInstruction::SkipIfKeyIsPressed(0xF) + ProcessorInstruction::SkipIfKeyIsPressed { vx: 0xF } ) } @@ -642,7 +642,7 @@ mod tests { let instruction = Instruction::new([0xEF, 0xA1]); assert_eq!( instruction.processor_instruction, - ProcessorInstruction::SkipIfKeyIsNotPressed(0xF) + ProcessorInstruction::SkipIfKeyIsNotPressed { vx: 0xF } ) } @@ -651,7 +651,7 @@ mod tests { let instruction = Instruction::new([0xFE, 0x0A]); assert_eq!( instruction.processor_instruction, - ProcessorInstruction::GetKeyBlocking(0xE) + ProcessorInstruction::GetKeyBlocking { vx: 0xF } ) } }