Skip to main content

Reader

Struct Reader 

Source
pub struct Reader {
    pub header: Header,
    /* private fields */
}
Expand description

Index reader — mmaps the shard file for zero-copy lookups.

Fields§

§header: Header

Parsed shard header containing section offsets and sizes.

Implementations§

Source§

impl Reader

Source

pub fn open(path: &Path) -> Result<Self>

Open and memory-map an index file for reading.

§Errors

Returns an error if the file cannot be opened, memory-mapped, or its header is invalid.

Source

pub fn get_last_modified(root: &Path) -> Result<u64>

Get the last modification time among all source files in the tree.

§Errors

Returns an error if the directory walk fails or metadata cannot be read.

Source

pub fn get_trigram(&self, trigram: Trigram) -> Option<TrigramInfo>

Binary search the trigram table. Returns None if the trigram is unknown.

When CDX compression is active, performs a two-level search: first on the block index, then within the decompressed block.

Source

pub fn decode_postings(&self, info: &TrigramInfo) -> Result<PostingList>

Decode the posting list for a given trigram info.

§Errors

Returns an error if the posting data is out of bounds or corrupted.

Source

pub fn get_file(&self, file_id: u32) -> Result<FileInfo>

Retrieve file metadata by its ID.

§Errors

Returns an error if the file ID is out of bounds or the file table entry is malformed.

Source

pub fn bloom_may_contain(&self, file_id: u32, trigram: Trigram) -> bool

Check if a bloom filter for a file may contain a trigram.

Returns true if the trigram may be present (conservative) or if any error occurs reading the bloom data (safe default: assume present).

Source

pub const fn metadata(&self) -> ShardMetadata

Retrieve high-level shard metadata without parsing the full header.

Source

pub fn is_stale(&self, path: &Path) -> bool

Detect whether the shard file on disk has been rebuilt under this live mmap.

Returns true if the inode or file size differs, or if the file no longer exists. A stale reader should be dropped and reopened.

On Unix: uses inode comparison (inode changes on atomic rename). On non-Unix: uses file size comparison only (Windows file locking prevents rebuild under live mmap, so size-only detection is sufficient).

Auto Trait Implementations§

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more