Skip to main content

KeyFile

Struct KeyFile 

Source
pub struct KeyFile { /* private fields */ }
Expand description

Read-only KEY/BIF lookup wrapper.

Implementations§

Source§

impl KeyFile

Source

pub fn read_from_file(key_path: impl AsRef<Path>) -> Result<Self, KeyFileError>

Reads a KEY file and binds BIF lookups to the KEY parent directory.

Source

pub fn read_from_file_with_base( key_path: impl AsRef<Path>, bif_base_path: impl AsRef<Path>, ) -> Result<Self, KeyFileError>

Reads a KEY file and binds BIF lookups to an explicit base directory.

Source

pub fn key_path(&self) -> &Path

Returns the KEY path.

Source

pub fn bif_base_path(&self) -> &Path

Returns the BIF base path used for KEY filename resolution.

Source

pub fn key(&self) -> &Key

Returns the parsed KEY value.

Source

pub fn resource_entry( &self, resref: &ResRef, resource_type: ResourceTypeCode, ) -> Option<&KeyResourceEntry>

Returns the first matching KEY entry for (resref, type).

Source

pub fn bif_path_by_index(&self, bif_index: u32) -> Option<PathBuf>

Resolves one BIF path by KEY BIF index.

Resolution order:

  1. direct <base>/<key-relative-path>
  2. <base>/data/<key-relative-path>
  3. case-insensitive indexed relative path match
  4. case-insensitive indexed basename match
Source

pub fn read_bif_by_index(&self, bif_index: u32) -> Result<Bif, KeyFileError>

Reads one BIF archive by KEY BIF index.

Source

pub fn resource( &self, resref: &ResRef, resource_type: ResourceTypeCode, ) -> Result<Option<Vec<u8>>, KeyFileError>

Resolves one payload by (resref, type).

Returns Ok(None) when the KEY has no matching entry.

This uses seek-based I/O to read only the requested resource from the BIF file, avoiding loading the entire (often hundreds of MB) BIF into memory.

Source

pub fn read_resource_by_seek( &self, bif_index: u32, resource_id: ResourceId, ) -> Result<Vec<u8>, KeyFileError>

Reads a single resource from a BIF file using seek-based I/O.

Instead of loading the entire BIF into memory, this reads only the BIF variable table header (a few KB) and then seeks directly to the requested resource’s data. This is dramatically more memory-efficient for large BIF files.

Trait Implementations§

Source§

impl Clone for KeyFile

Source§

fn clone(&self) -> KeyFile

Returns a duplicate 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 Debug for KeyFile

Source§

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

Formats the value using the given formatter. Read more

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

Source§

fn az<Dst>(self) -> Dst
where T: Cast<Dst>,

Casts the value.
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<Src, Dst> CastFrom<Src> for Dst
where Src: Cast<Dst>,

Source§

fn cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> CheckedAs for T

Source§

fn checked_as<Dst>(self) -> Option<Dst>
where T: CheckedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> CheckedCastFrom<Src> for Dst
where Src: CheckedCast<Dst>,

Source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> OverflowingAs for T

Source§

fn overflowing_as<Dst>(self) -> (Dst, bool)
where T: OverflowingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dst
where Src: OverflowingCast<Dst>,

Source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
Source§

impl<T> SaturatingAs for T

Source§

fn saturating_as<Dst>(self) -> Dst
where T: SaturatingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dst
where Src: SaturatingCast<Dst>,

Source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> StrictAs for T

Source§

fn strict_as<Dst>(self) -> Dst
where T: StrictCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> StrictCastFrom<Src> for Dst
where Src: StrictCast<Dst>,

Source§

fn strict_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

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

Source§

fn unwrapped_as<Dst>(self) -> Dst
where T: UnwrappedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dst
where Src: UnwrappedCast<Dst>,

Source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> WrappingAs for T

Source§

fn wrapping_as<Dst>(self) -> Dst
where T: WrappingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> WrappingCastFrom<Src> for Dst
where Src: WrappingCast<Dst>,

Source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.