pub struct FrontCodedList<D: AsRef<[u8]>, P: AsRef<[u8]>> { /* private fields */ }
Expand description

Front coded list, it takes a list of strings and encode them in a way that the common prefix between strings is encoded only once.

The encoding is done in blocks of k strings, the first string is encoded without compression, the other strings are encoded with the common prefix removed.

See the it.unimi.dsi.fastutil.bytes.ByteArrayFrontCodedBigList documentation or the implementation for details

Implementations§

source§

impl FrontCodedList<Mmap, Mmap>

source

pub fn load<P: AsRef<Path>>(base_path: P) -> Result<Self>

source§

impl<D: AsRef<[u8]>, P: AsRef<[u8]>> FrontCodedList<D, P>

source

pub fn get_inplace(&self, index: usize, result: &mut Vec<u8>)

Write the index-th string to result as bytes. This is done to avoid allocating a new string for every query.

Trait Implementations§

source§

impl<D: Clone + AsRef<[u8]>, P: Clone + AsRef<[u8]>> Clone for FrontCodedList<D, P>

source§

fn clone(&self) -> FrontCodedList<D, P>

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<D: Debug + AsRef<[u8]>, P: Debug + AsRef<[u8]>> Debug for FrontCodedList<D, P>

source§

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

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

impl<D: AsRef<[u8]>, P: AsRef<[u8]>> GetIndex for &FrontCodedList<D, P>

source§

fn get(&self, index: usize) -> Option<Self::Output>

Returns the n-th bytestring, or None if index is larger than the length

source§

unsafe fn get_unchecked(&self, index: usize) -> Self::Output

Returns the n-th bytestring

Panics

If index is out of bound

§

type Output = Vec<u8>

source§

fn len(&self) -> usize

Returns the total number of items in the collections

Auto Trait Implementations§

§

impl<D, P> RefUnwindSafe for FrontCodedList<D, P>where D: RefUnwindSafe, P: RefUnwindSafe,

§

impl<D, P> Send for FrontCodedList<D, P>where D: Send, P: Send,

§

impl<D, P> Sync for FrontCodedList<D, P>where D: Sync, P: Sync,

§

impl<D, P> Unpin for FrontCodedList<D, P>where D: Unpin, P: Unpin,

§

impl<D, P> UnwindSafe for FrontCodedList<D, P>where D: UnwindSafe, P: UnwindSafe,

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
§

impl<T> CastableFrom<T> for T

§

fn cast_from(value: T) -> T

Call Self as W
§

impl<T, U> CastableInto<U> for Twhere U: CastableFrom<T>,

§

fn cast(self) -> U

Call W::cast_from(self)
§

impl<T> DowncastableFrom<T> for T

§

fn downcast_from(value: T) -> T

Truncate the current UnsignedInt to a possibly smaller size
§

impl<T, U> DowncastableInto<U> for Twhere U: DowncastableFrom<T>,

§

fn downcast(self) -> U

Call W::downcast_from(self)
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, W> HasTypeWitness<W> for Twhere W: MakeTypeWitness<Arg = T>, T: ?Sized,

§

const WITNESS: W = W::MAKE

A constant of the type witness
§

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

§

type Type = T

The same type as Self, used to emulate type equality bounds (T == U) with associated type equality constraints (T: Identity<Type = U>).
§

const TYPE_EQ: TypeEq<T, <T as Identity>::Type> = TypeEq::NEW

Proof that Self is the same type as Self::Type, provides methods for casting between Self and Self::Type.
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.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

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

Initializes a with the given initializer. Read more
§

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

Dereferences the given pointer. Read more
§

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

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> Splat<T> for T

§

fn splat(value: T) -> T

§

impl<T> To<T> for T

§

fn to(self) -> T

source§

impl<T> ToOwned for Twhere T: Clone,

§

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 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.
§

impl<T> UpcastableFrom<T> for T

§

fn upcast_from(value: T) -> T

Extend the current UnsignedInt to a possibly bigger size.
§

impl<T, U> UpcastableInto<U> for Twhere U: UpcastableFrom<T>,

§

fn upcast(self) -> U

Call W::upcast_from(self)
§

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

§

fn vzip(self) -> V

§

impl<T> Allocation for Twhere T: RefUnwindSafe + Send + Sync,