namespace X86Disassembler.X86.Handlers.Jump; /// /// Handler for conditional jump instructions (0x70-0x7F) /// public class ConditionalJumpHandler : InstructionHandler { // Mnemonics for conditional jumps private static readonly string[] Mnemonics = [ "jo", "jno", "jb", "jnb", "jz", "jnz", "jbe", "jnbe", "js", "jns", "jp", "jnp", "jl", "jnl", "jle", "jnle" ]; /// /// Initializes a new instance of the ConditionalJumpHandler class /// /// The buffer containing the code to decode /// The instruction decoder that owns this handler /// The length of the buffer public ConditionalJumpHandler(byte[] codeBuffer, InstructionDecoder decoder, int length) : base(codeBuffer, decoder, length) { } /// /// Checks if this handler can decode the given opcode /// /// The opcode to check /// True if this handler can decode the opcode public override bool CanHandle(byte opcode) { // Conditional jumps are in the range 0x70-0x7F return opcode >= 0x70 && opcode <= 0x7F; } /// /// Decodes a conditional jump instruction /// /// The opcode of the instruction /// The instruction object to populate /// True if the instruction was successfully decoded public override bool Decode(byte opcode, Instruction instruction) { // Get the mnemonic from the table int index = opcode - 0x70; instruction.Mnemonic = Mnemonics[index]; // Check if we can read the offset byte if (!Decoder.CanReadByte()) { return false; } // Read the offset and calculate target address int position = Decoder.GetPosition(); sbyte offset = (sbyte)Decoder.ReadByte(); int targetAddress = position + 1 + offset; // Format the target address as a hexadecimal value instruction.Operands = $"0x{targetAddress:X8}"; return true; } }