#[repr(transparent)]pub struct PatternID(SmallIndex);
Expand description
The identifier of a pattern in an Aho-Corasick automaton.
It is represented by a u32
even on 64-bit systems in order to conserve
space. Namely, on all targets, this type guarantees that its value will
fit in a u32
, i32
, usize
and an isize
. This means that on 16-bit
targets, for example, this type’s maximum value will never overflow an
isize
, which means it will never overflow a i16
even though its
internal representation is still a u32
.
§Safety
While a PatternID
is meant to guarantee that its value fits into usize
without using as much space as a usize
on all targets, callers must
not rely on this property for safety. Callers may choose to rely on this
property for correctness however. For example, creating a StateID
with an
invalid value can be done in entirely safe code. This may in turn result in
panics or silent logical errors.
Tuple Fields§
§0: SmallIndex
Implementations§
source§impl PatternID
impl PatternID
sourcepub const LIMIT: usize = 2_147_483_647usize
pub const LIMIT: usize = 2_147_483_647usize
The total number of values that can be represented.
sourcepub fn new(value: usize) -> Result<PatternID, PatternIDError>
pub fn new(value: usize) -> Result<PatternID, PatternIDError>
Create a new value that is represented by a “small index.”
If the given index exceeds the maximum allowed value, then this returns an error.
sourcepub const fn new_unchecked(value: usize) -> PatternID
pub const fn new_unchecked(value: usize) -> PatternID
Create a new value without checking whether the given argument exceeds the maximum.
Using this routine with an invalid value will result in unspecified behavior, but not undefined behavior. In particular, an invalid ID value is likely to cause panics or possibly even silent logical errors.
Callers must never rely on this type to be within a certain range for memory safety.
sourcepub const fn from_u32_unchecked(index: u32) -> PatternID
pub const fn from_u32_unchecked(index: u32) -> PatternID
Create a new value from a u32
without checking whether the
given value exceeds the maximum.
Using this routine with an invalid value will result in unspecified behavior, but not undefined behavior. In particular, an invalid ID value is likely to cause panics or possibly even silent logical errors.
Callers must never rely on this type to be within a certain range for memory safety.
sourcepub const fn as_usize(&self) -> usize
pub const fn as_usize(&self) -> usize
Return the internal value as a usize
. This is guaranteed to
never overflow usize
.
sourcepub const fn as_u64(&self) -> u64
pub const fn as_u64(&self) -> u64
Return the internal value as a u64
. This is guaranteed to
never overflow.
sourcepub const fn as_u32(&self) -> u32
pub const fn as_u32(&self) -> u32
Return the internal value as a u32
. This is guaranteed to
never overflow u32
.
sourcepub const fn as_i32(&self) -> i32
pub const fn as_i32(&self) -> i32
Return the internal value as a i32
. This is guaranteed to
never overflow an i32
.
sourcepub fn one_more(&self) -> usize
pub fn one_more(&self) -> usize
Returns one more than this value as a usize.
Since values represented by a “small index” have constraints
on their maximum value, adding 1
to it will always fit in a
usize
, u32
and a i32
.
sourcepub fn from_ne_bytes(bytes: [u8; 4]) -> Result<PatternID, PatternIDError>
pub fn from_ne_bytes(bytes: [u8; 4]) -> Result<PatternID, PatternIDError>
Decode this value from the bytes given using the native endian byte order for the current target.
If the decoded integer is not representable as a small index for the current target, then this returns an error.
sourcepub fn from_ne_bytes_unchecked(bytes: [u8; 4]) -> PatternID
pub fn from_ne_bytes_unchecked(bytes: [u8; 4]) -> PatternID
Decode this value from the bytes given using the native endian byte order for the current target.
This is analogous to new_unchecked
in that is does not check
whether the decoded integer is representable as a small index.
sourcepub fn to_ne_bytes(&self) -> [u8; 4]
pub fn to_ne_bytes(&self) -> [u8; 4]
Return the underlying integer as raw bytes in native endian format.
sourcepub(crate) fn iter(len: usize) -> PatternIDIter ⓘ
pub(crate) fn iter(len: usize) -> PatternIDIter ⓘ
Returns an iterator over all values from 0 up to and not including the given length.
If the given length exceeds this type’s limit, then this panics.
Trait Implementations§
source§impl From<PatternID> for SmallIndex
impl From<PatternID> for SmallIndex
source§fn from(pid: PatternID) -> SmallIndex
fn from(pid: PatternID) -> SmallIndex
source§impl From<SmallIndex> for PatternID
impl From<SmallIndex> for PatternID
source§fn from(index: SmallIndex) -> PatternID
fn from(index: SmallIndex) -> PatternID
source§impl Ord for PatternID
impl Ord for PatternID
source§impl PartialOrd for PatternID
impl PartialOrd for PatternID
impl Copy for PatternID
impl Eq for PatternID
impl StructuralPartialEq for PatternID
Auto Trait Implementations§
impl Freeze for PatternID
impl RefUnwindSafe for PatternID
impl Send for PatternID
impl Sync for PatternID
impl Unpin for PatternID
impl UnwindSafe for PatternID
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)