Struct RadixTrieN

Source
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

Source

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.

Source

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.

Source

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.

Source

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§

Blanket Implementations§

Source§

impl<T> AllocForAny<T> for T

Source§

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

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> 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> 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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V