Skip to main content

ChunkReader

Struct ChunkReader 

Source
pub struct ChunkReader<R: Read + Seek> { /* private fields */ }
Expand description

Reader for chunked Data.db files (NB format)

This reader handles NB format Data.db files where:

  • No magic number or header exists (file starts with compressed data)
  • Each compressed chunk is followed by a 4-byte CRC32 checksum
  • CRC32 uses Java’s java.util.zip.CRC32 algorithm (IEEE polynomial 0x04C11DB7)
  • Checksums are stored in big-endian format

Implementations§

Source§

impl<R: Read + Seek> ChunkReader<R>

Source

pub fn new( reader: R, compression_info: CompressionInfo, total_file_size: u64, ) -> Self

Create new chunk reader

§Arguments
  • reader - The underlying reader for Data.db file
  • compression_info - Parsed CompressionInfo containing chunk metadata
  • total_file_size - Total size of the Data.db file in bytes
§Returns

A new ChunkReader instance ready to read chunks

Source

pub fn read_chunk(&mut self, chunk_index: usize) -> Result<Vec<u8>>

Read and validate a specific chunk by index

This method:

  1. Seeks to the chunk offset in Data.db
  2. Reads the compressed chunk bytes
  3. Reads the trailing 4-byte CRC32 checksum
  4. Validates the CRC32 (fail-fast on mismatch)
§Arguments
  • chunk_index - Zero-based index of the chunk to read
§Returns

Compressed chunk bytes ready for decompression

§Errors

Returns an error if:

  • Chunk index is invalid
  • I/O error occurs during reading
  • CRC32 validation fails
Source

pub fn read_all_chunks(&mut self) -> Result<Vec<Vec<u8>>>

Read all chunks and validate CRC32 for each

This is a convenience method that reads all chunks in sequential order.

§Returns

A vector of compressed chunk byte arrays, one per chunk

§Errors

Returns an error on the first chunk that fails to read or validate

Source

pub fn chunk_count(&self) -> usize

Get the number of chunks in this file

Source

pub fn compression_algorithm(&self) -> &str

Get the compression algorithm name

Source

pub fn chunk_length(&self) -> u32

Get the uncompressed chunk size

Auto Trait Implementations§

§

impl<R> Freeze for ChunkReader<R>
where R: Freeze,

§

impl<R> RefUnwindSafe for ChunkReader<R>
where R: RefUnwindSafe,

§

impl<R> Send for ChunkReader<R>
where R: Send,

§

impl<R> Sync for ChunkReader<R>
where R: Sync,

§

impl<R> Unpin for ChunkReader<R>
where R: Unpin,

§

impl<R> UnsafeUnpin for ChunkReader<R>
where R: UnsafeUnpin,

§

impl<R> UnwindSafe for ChunkReader<R>
where R: UnwindSafe,

Blanket Implementations§

Source§

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

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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

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> 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> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

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.