From 4cba27de9748aba40711f9ac5686936b6140531a Mon Sep 17 00:00:00 2001 From: Denis Nutiu Date: Wed, 11 Dec 2024 00:22:57 +0200 Subject: [PATCH] use c-like struct for SkipEqualVXData & SkipNotEqualVXData instruction --- src/emulator.rs | 4 ++-- src/instruction.rs | 24 ++++++++++++------------ 2 files changed, 14 insertions(+), 14 deletions(-) diff --git a/src/emulator.rs b/src/emulator.rs index 167a02c..4ed7368 100644 --- a/src/emulator.rs +++ b/src/emulator.rs @@ -345,14 +345,14 @@ where trace!("Generate random number"); self.registers[vx as usize] = rand::thread_rng().gen_range(0x00..0xFF) & mask } - ProcessorInstruction::SkipEqualVXData(vx, data) => { + ProcessorInstruction::SkipEqualVXData { vx, data} => { trace!("SkipEqualVXData"); let vx_data = self.registers[vx as usize]; if vx_data == data { self.program_counter += 2 } } - ProcessorInstruction::SkipNotEqualVXData(vx, data) => { + ProcessorInstruction::SkipNotEqualVXData { vx, data} => { trace!("SkipNotEqualVXData"); let vx_data = self.registers[vx as usize]; if vx_data != data { diff --git a/src/instruction.rs b/src/instruction.rs index 0e79d58..0562edc 100644 --- a/src/instruction.rs +++ b/src/instruction.rs @@ -55,9 +55,9 @@ pub enum ProcessorInstruction { /// Generates a random number ANDed with the data and stores it in VX. GenerateRandomNumber { vx: u8, mask: u8 }, /// Skips the next instruction if VX is equal to data. - SkipEqualVXData(u8, u8), + SkipEqualVXData {vx: u8, data: u8}, /// Skip the next instruction if VX is not equal to data. - SkipNotEqualVXData(u8, u8), + SkipNotEqualVXData {vx: u8, data: u8}, /// Skips the next instruction if VX is equal to VY. SkipEqualVXVY(u8, u8), /// Skip the next instruction if VX is not equal to VY. @@ -205,14 +205,14 @@ impl Instruction { vx: Self::grab_first_nibble(data), mask: Self::grab_last_byte(data), }, - (0x3, _, _, _) => ProcessorInstruction::SkipEqualVXData( - Self::grab_first_nibble(data), - Self::grab_last_byte(data), - ), - (0x4, _, _, _) => ProcessorInstruction::SkipNotEqualVXData( - Self::grab_first_nibble(data), - Self::grab_last_byte(data), - ), + (0x3, _, _, _) => ProcessorInstruction::SkipEqualVXData{ + vx: Self::grab_first_nibble(data), + data: Self::grab_last_byte(data), + }, + (0x4, _, _, _) => ProcessorInstruction::SkipNotEqualVXData { + vx: Self::grab_first_nibble(data), + data: Self::grab_last_byte(data), + }, (0x5, _, _, 0x0) => ProcessorInstruction::SkipEqualVXVY( Self::grab_first_nibble(data), Self::grab_middle_nibble(data), @@ -365,7 +365,7 @@ mod tests { let instruction = Instruction::new([0x3A, 0xBC]); assert_eq!( instruction.processor_instruction, - ProcessorInstruction::SkipEqualVXData(0xA, 0xBC) + ProcessorInstruction::SkipEqualVXData{vx: 0xA, data: 0xBC} ) } @@ -374,7 +374,7 @@ mod tests { let instruction = Instruction::new([0x4A, 0xBC]); assert_eq!( instruction.processor_instruction, - ProcessorInstruction::SkipNotEqualVXData(0xA, 0xBC) + ProcessorInstruction::SkipNotEqualVXData{vx: 0xA, data: 0xBC} ) }