From 5dd11bc74cf192690c9793b359f930510fd0bc6c Mon Sep 17 00:00:00 2001 From: Denis Nutiu Date: Tue, 10 Dec 2024 23:55:35 +0200 Subject: [PATCH] use c-like struct for Call instruction --- src/emulator.rs | 2 +- src/input.rs | 2 +- src/instruction.rs | 8 +++++--- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/src/emulator.rs b/src/emulator.rs index f245946..91635aa 100644 --- a/src/emulator.rs +++ b/src/emulator.rs @@ -263,7 +263,7 @@ where trace!("Return to {value:04x}"); self.program_counter = value; } - ProcessorInstruction::Call(address) => { + ProcessorInstruction::Call { address } => { trace!("Call {address:04x}"); // Save PC to the stack self.stack.push(self.program_counter); diff --git a/src/input.rs b/src/input.rs index 33e41b7..9f39d64 100644 --- a/src/input.rs +++ b/src/input.rs @@ -94,4 +94,4 @@ impl Drop for CrossTermInput { fn drop(&mut self) { disable_raw_mode().expect("failed to disable terminal raw mode."); } -} \ No newline at end of file +} diff --git a/src/instruction.rs b/src/instruction.rs index 6ece8eb..b3bb595 100644 --- a/src/instruction.rs +++ b/src/instruction.rs @@ -27,7 +27,7 @@ pub enum ProcessorInstruction { /// Draws to the screen. Draw { vx: u8, vy: u8, rows: u8 }, /// Call sets PC to the address and saves the return address on the stack - Call(u16), + Call { address: u16 }, /// Pops the stack and sets the PC Return, /// Set VX to the value of VY @@ -159,7 +159,9 @@ impl Instruction { } } (0x0, 0x0, 0xE, 0xE) => ProcessorInstruction::Return, - (0x2, _, _, _) => ProcessorInstruction::Call(Self::grab_inner_data(data)), + (0x2, _, _, _) => ProcessorInstruction::Call { + address: Self::grab_inner_data(data), + }, (0x8, _, _, 0x0) => ProcessorInstruction::Set( Self::grab_first_nibble(data), Self::grab_middle_nibble(data), @@ -343,7 +345,7 @@ mod tests { let instruction = Instruction::new([0x2A, 0xBC]); assert_eq!( instruction.processor_instruction, - ProcessorInstruction::Call(0xABC) + ProcessorInstruction::Call { address: 0xABC } ) }