LCOV - code coverage report
Current view: top level - src/assembly/x86 - instruction.rs (source / functions) Coverage Total Hit
Test: lief.lcov Lines: 0.0 % 21 0
Test Date: 2025-01-11:00:00:00 Functions: 0.0 % 5 0

            Line data    Source code
       1              : use lief_ffi as ffi;
       2              : 
       3              : use crate::common::FromFFI;
       4              : use crate::assembly;
       5              : use super::Opcode;
       6              : 
       7              : use crate::declare_fwd_iterator;
       8              : use crate::assembly::x86;
       9              : 
      10              : /// This structure represents a x86/x86-64 instruction
      11              : pub struct Instruction {
      12              :     ptr: cxx::UniquePtr<ffi::asm_x86_Instruction>,
      13              : }
      14              : 
      15              : impl FromFFI<ffi::asm_x86_Instruction> for Instruction {
      16            0 :     fn from_ffi(ptr: cxx::UniquePtr<ffi::asm_x86_Instruction>) -> Self {
      17            0 :         Self {
      18            0 :             ptr,
      19            0 :         }
      20            0 :     }
      21              : }
      22              : 
      23              : impl assembly::Instruction for Instruction {
      24              :     #[doc(hidden)]
      25            0 :     fn as_generic(&self) -> &ffi::asm_Instruction {
      26            0 :         self.ptr.as_ref().unwrap().as_ref()
      27            0 :     }
      28              : }
      29              : 
      30              : impl Instruction {
      31              :     /// The instruction opcode as defined in LLVM
      32            0 :     pub fn opcode(&self) -> Opcode {
      33            0 :         Opcode::from(self.ptr.opcode())
      34            0 :     }
      35              : 
      36              :     /// Return an iterator over the [`x86::Operands`] operands
      37            0 :     pub fn operands(&self) -> Operands {
      38            0 :         Operands::new(self.ptr.operands())
      39            0 :     }
      40              : }
      41              : 
      42            0 : declare_fwd_iterator!(
      43            0 :     Operands,
      44            0 :     x86::Operands,
      45            0 :     ffi::asm_Instruction,
      46            0 :     ffi::asm_x86_Operand,
      47            0 :     ffi::asm_x86_Instruction_it_operands
      48            0 : );
        

Generated by: LCOV version 2.1-1