Struct memchr::arch::generic::packedpair::Finder

source ·
pub(crate) struct Finder<V> {
    pair: Pair,
    v1: V,
    v2: V,
    min_haystack_len: usize,
}
Expand description

A generic architecture dependent “packed pair” finder.

This finder picks two bytes that it believes have high predictive power for indicating an overall match of a needle. Depending on whether Finder::find or Finder::find_prefilter is used, it reports offsets where the needle matches or could match. In the prefilter case, candidates are reported whenever the Pair of bytes given matches.

This is architecture dependent because it uses specific vector operations to look for occurrences of the pair of bytes.

This type is not meant to be exported and is instead meant to be used as the implementation for architecture specific facades. Why? Because it’s a bit of a quirky API that requires inline(always) annotations. And pretty much everything has safety obligations due (at least) to the caller needing to inline calls into routines marked with #[target_feature(enable = "...")].

Fields§

§pair: Pair§v1: V§v2: V§min_haystack_len: usize

Implementations§

source§

impl<V: Vector> Finder<V>

source

pub(crate) unsafe fn new(needle: &[u8], pair: Pair) -> Finder<V>

Create a new pair searcher. The searcher returned can either report exact matches of needle or act as a prefilter and report candidate positions of needle.

§Safety

Callers must ensure that whatever vector type this routine is called with is supported by the current environment.

Callers must also ensure that needle.len() >= 2.

source

pub(crate) unsafe fn find( &self, haystack: &[u8], needle: &[u8], ) -> Option<usize>

Searches the given haystack for the given needle. The needle given should be the same as the needle that this finder was initialized with.

§Panics

When haystack.len() is less than Finder::min_haystack_len.

§Safety

Since this is meant to be used with vector functions, callers need to specialize this inside of a function with a target_feature attribute. Therefore, callers must ensure that whatever target feature is being used supports the vector functions that this function is specialized for. (For the specific vector functions used, see the Vector trait implementations.)

source

pub(crate) unsafe fn find_prefilter(&self, haystack: &[u8]) -> Option<usize>

Searches the given haystack for offsets that represent candidate matches of the needle given to this finder’s constructor. The offsets returned, if they are a match, correspond to the starting offset of needle in the given haystack.

§Panics

When haystack.len() is less than Finder::min_haystack_len.

§Safety

Since this is meant to be used with vector functions, callers need to specialize this inside of a function with a target_feature attribute. Therefore, callers must ensure that whatever target feature is being used supports the vector functions that this function is specialized for. (For the specific vector functions used, see the Vector trait implementations.)

source

unsafe fn find_in_chunk( &self, needle: &[u8], cur: *const u8, end: *const u8, mask: V::Mask, ) -> Option<usize>

Search for an occurrence of our byte pair from the needle in the chunk pointed to by cur, with the end of the haystack pointed to by end. When an occurrence is found, memcmp is run to check if a match occurs at the corresponding position.

mask should have bits set corresponding the positions in the chunk in which matches are considered. This is only used for the last vector load where the beginning of the vector might have overlapped with the last load in the main loop. The mask lets us avoid visiting positions that have already been discarded as matches.

§Safety

It must be safe to do an unaligned read of size(V) bytes starting at both (cur + self.index1) and (cur + self.index2). It must also be safe to do unaligned loads on cur up to (end - needle.len()).

source

unsafe fn find_prefilter_in_chunk(&self, cur: *const u8) -> Option<usize>

Search for an occurrence of our byte pair from the needle in the chunk pointed to by cur, with the end of the haystack pointed to by end. When an occurrence is found, memcmp is run to check if a match occurs at the corresponding position.

§Safety

It must be safe to do an unaligned read of size(V) bytes starting at both (cur + self.index1) and (cur + self.index2). It must also be safe to do unaligned reads on cur up to (end - needle.len()).

source

pub(crate) fn pair(&self) -> &Pair

Returns the pair of offsets (into the needle) used to check as a predicate before confirming whether a needle exists at a particular position.

source

pub(crate) fn min_haystack_len(&self) -> usize

Returns the minimum haystack length that this Finder can search.

Providing a haystack to this Finder shorter than this length is guaranteed to result in a panic.

Trait Implementations§

source§

impl<V: Clone> Clone for Finder<V>

source§

fn clone(&self) -> Finder<V>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<V: Debug> Debug for Finder<V>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<V: Copy> Copy for Finder<V>

Auto Trait Implementations§

§

impl<V> Freeze for Finder<V>
where V: Freeze,

§

impl<V> RefUnwindSafe for Finder<V>
where V: RefUnwindSafe,

§

impl<V> Send for Finder<V>
where V: Send,

§

impl<V> Sync for Finder<V>
where V: Sync,

§

impl<V> Unpin for Finder<V>
where V: Unpin,

§

impl<V> UnwindSafe for Finder<V>
where V: UnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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 T
where 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> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

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

source§

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 T
where U: TryFrom<T>,

source§

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.