pub struct Scanner(/* private fields */);
Expand description

Single result IDA-style pattern scanner

A pattern scanner that searches for an IDA-style pattern and returns the pointer to the first occurrence in the binary.

Implementations§

source§

impl Scanner

source

pub fn new(pattern: &str) -> Self

Create a new Scanner instance

Example
use lightningscanner::Scanner;

let scanner = Scanner::new("48 89 5c 24 ?? 48 89 6c");
source

pub fn find( &self, preferred_scan_mode: Option<ScanMode>, binary: &[u8] ) -> ScanResult

Find the first occurence of the pattern in the binary

Params
  • preferred_scan_mode - preferred scan mode to use (Avx2, Sse42, Scalar) if the preferred mode is not available, will choose the fastest out of the availble ones

  • binary - binary to search for the pattern in

Example
use lightningscanner::Scanner;

let binary = [0xab, 0xec, 0x48, 0x89, 0x5c, 0x24, 0xee, 0x48, 0x89, 0x6c];

let scanner = Scanner::new("48 89 5c 24 ?? 48 89 6c");
let result = scanner.find(None, &binary);

println!("{:?}", result);
source

pub unsafe fn find_ptr( &self, preferred_scan_mode: Option<ScanMode>, binary_ptr: *const u8, binary_size: usize ) -> ScanResult

Find the first occurence of the pattern in the binary

Params
  • preferred_scan_mode - preferred scan mode to use (Avx2, Sse42, Scalar) if the preferred mode is not available, will choose the fastest out of the availble ones

  • binary_ptr - pointer to the first element of the binary to search the pattern in

  • binary_size - binary size

Safety
  • binary_ptr - is a valid pointer

  • binary_size - corresponds to a valid size of binary

Example
use lightningscanner::Scanner;

let binary = [0xab, 0xec, 0x48, 0x89, 0x5c, 0x24, 0xee, 0x48, 0x89, 0x6c];

let scanner = Scanner::new("48 89 5c 24 ?? 48 89 6c");
let result = unsafe { scanner.find_ptr(None, binary.as_ptr(), binary.len()) };

println!("{:?}", result);

Trait Implementations§

source§

impl From<Pattern> for Scanner

source§

fn from(value: Pattern) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.