pub struct RadixTrieN(Vec<Trie<&'static str, Vec<&'static [&'static str]>>>);
Expand description
A container wrapping a collection of radix tries that map static string slices to lists of string slice arrays. This structure is designed to group multiple tries, enabling efficient organization and retrieval of sequences of static strings by leveraging trie-based lookups for operations such as prefix search and related string queries.
Tuple Fields§
§0: Vec<Trie<&'static str, Vec<&'static [&'static str]>>>
Implementations§
Source§impl RadixTrieN
impl RadixTrieN
Sourcepub fn new(len: usize) -> Self
pub fn new(len: usize) -> Self
Creates a new instance of the specialized trie collection with a specified number of inner trie elements.
Initializes the generator by taking a length parameter and generating a vector with that many default trie structures. Each inner trie is created using its default constructor, and the resulting collection is encapsulated within the instance.
Sourcepub fn insert(&mut self, key: &'static [&'static str])
pub fn insert(&mut self, key: &'static [&'static str])
Inserts a provided key composed of static string slices into a multi-layer trie structure. This function iterates over the key’s components paired with corresponding trie elements and updates each trie by appending the key to an existing entry or inserting a new entry when none exists.
Sourcepub fn superfixes(
&self,
key: &'static [&'static str],
) -> impl Iterator<Item = &'static [&'static str]> + '_
pub fn superfixes( &self, key: &'static [&'static str], ) -> impl Iterator<Item = &'static [&'static str]> + '_
Returns an iterator over candidate key slices that are recognized as superfixes relative to the provided key.
Determines the most significant component of the key based on length and queries the corresponding subtrie, then filters and flattens the resulting values to yield only those keys that satisfy the superfix property with respect to the original key.
Sourcepub fn prefixes(
&self,
key: &'static [&'static str],
) -> impl Iterator<Item = &'static [&'static str]> + '_
pub fn prefixes( &self, key: &'static [&'static str], ) -> impl Iterator<Item = &'static [&'static str]> + '_
Returns an iterator that produces all stored string sequences from the underlying trie that qualify as prefixes of the provided key sequence.
Operates by selecting the key element with the smallest length to determine the appropriate subtrie, then iterates over candidate values from that subtrie. The iterator is filtered to include only those sequence elements that satisfy the prefix relationship with the full key as determined by a predicate.
Auto Trait Implementations§
impl Freeze for RadixTrieN
impl RefUnwindSafe for RadixTrieN
impl Send for RadixTrieN
impl Sync for RadixTrieN
impl Unpin for RadixTrieN
impl UnwindSafe for RadixTrieN
Blanket Implementations§
Source§impl<T> AllocForAny<T> for T
impl<T> AllocForAny<T> for T
Source§fn galloc(self) -> &'static T
fn galloc(self) -> &'static T
Provides a method to allocate an instance of T
on the heap with a static lifetime.
This implementation of galloc
takes ownership of the T
instance and uses the alloc
function to place it in a location with a static lifetime, presumably managing it in a way that ensures its persistence for the duration of the program.
This can be particularly useful for scenarios where a static lifetime is required, such as when interfacing with systems or patterns that necessitate global state or long-lived data.
Source§fn galloc_mut(self) -> &'static T
fn galloc_mut(self) -> &'static T
Provides a method that moves the instance and returns a reference to it allocated with a static lifetime.
This method utilizes alloc_mut
to perform the allocation, likely involving allocating the resource in a manner that ensures it lives for the entire duration of the application.
These semantics allow the user to safely assume that the reference will not expire during the program’s execution, making it suitable for long-lived data structures or operations that require such guarantees.
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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more