Struct DataEntry

Source
pub struct DataEntry<'a, 'c> {
    path: PathBuf,
    entry: Entry<'a, CompressionDecoder<'c>>,
}
Expand description

A data file contained in the tar archive of an alpm-package file.

Wraps a PathBuf that indicates the location of the file in the tar archive and a tar Entry that provides access to the data of the entry in the tar archive.

Read is implemented to allow directly reading the contents of the tar archive entry.

§Notes

Uses two lifetimes for the entry field:

Fields§

§path: PathBuf

The path of the data entry in the package archive.

§entry: Entry<'a, CompressionDecoder<'c>>

The raw tar entry that contains the data of the entry.

Implementations§

Source§

impl<'a, 'c> DataEntry<'a, 'c>

Source

pub fn path(&self) -> &Path

Returns the path of the data entry in the tar archive of the package.

Source

pub fn content(&mut self) -> Result<Vec<u8>, Error>

Returns the content of the data entry.

§Errors

Returns an error if Entry::read_to_end fails.

Source

pub fn is_dir(&self) -> bool

Checks whether the DataEntry represents a directory.

Returns true if the DataEntry represents a directory, false otherwise.

§Note

This is a convenience method for comparing the EntryType of the Entry::header contained in the DataEntry with EntryType::Directory.

Source

pub fn is_file(&self) -> bool

Checks whether the DataEntry represents a regular file.

Returns true if the DataEntry represents a regular file, false otherwise.

§Note

This is a convenience method for comparing the EntryType of the Entry::header contained in the DataEntry with EntryType::Regular.

Checks whether the DataEntry represents a symlink.

Returns true if the DataEntry represents a symlink, false otherwise.

§Note

This is a convenience method for comparing the EntryType of the Entry::header contained in the DataEntry with EntryType::Symlink.

Source

pub fn permissions(&self) -> Result<u32, Error>

Returns the access permissions that apply for the DataEntry.

§Notes
  • This is a convenience method for retrieving the mode of the Entry::header contained in the DataEntry.
  • It returns the mode masked with 0o7777 to ensure only the permission bits are returned.
§Errors

Returns an error if retrieving the mode from the entry’s header fails.

Source

pub fn entry(&'a self) -> &'a Entry<'a, CompressionDecoder<'c>>

Returns a reference to the underlying tar Entry.

This is useful for accessing metadata of the entry, such as its header or path.

Trait Implementations§

Source§

impl Debug for DataEntry<'_, '_>

Source§

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

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

impl Read for DataEntry<'_, '_>

Source§

fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error>

Reads data from the entry into the provided buffer.

Delegates to Entry::read.

§Errors

Returns an error if reading from the entry fails.

1.36.0 · Source§

fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>

Like read, except that it reads into a slice of buffers. Read more
Source§

fn is_read_vectored(&self) -> bool

🔬This is a nightly-only experimental API. (can_vector)
Determines if this Reader has an efficient read_vectored implementation. Read more
1.0.0 · Source§

fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>

Reads all bytes until EOF in this source, placing them into buf. Read more
1.0.0 · Source§

fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>

Reads all bytes until EOF in this source, appending them to buf. Read more
1.6.0 · Source§

fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>

Reads the exact number of bytes required to fill buf. Read more
Source§

fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Pull some bytes from this source into the specified buffer. Read more
Source§

fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>

🔬This is a nightly-only experimental API. (read_buf)
Reads the exact number of bytes required to fill cursor. Read more
1.0.0 · Source§

fn by_ref(&mut self) -> &mut Self
where Self: Sized,

Creates a “by reference” adaptor for this instance of Read. Read more
1.0.0 · Source§

fn bytes(self) -> Bytes<Self>
where Self: Sized,

Transforms this Read instance to an Iterator over its bytes. Read more
1.0.0 · Source§

fn chain<R>(self, next: R) -> Chain<Self, R>
where R: Read, Self: Sized,

Creates an adapter which will chain this stream with another. Read more
1.0.0 · Source§

fn take(self, limit: u64) -> Take<Self>
where Self: Sized,

Creates an adapter which will read at most limit bytes from it. Read more

Auto Trait Implementations§

§

impl<'a, 'c> Freeze for DataEntry<'a, 'c>

§

impl<'a, 'c> !RefUnwindSafe for DataEntry<'a, 'c>

§

impl<'a, 'c> !Send for DataEntry<'a, 'c>

§

impl<'a, 'c> !Sync for DataEntry<'a, 'c>

§

impl<'a, 'c> Unpin for DataEntry<'a, 'c>

§

impl<'a, 'c> !UnwindSafe for DataEntry<'a, 'c>

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, 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> Same for T

Source§

type Output = T

Should always be Self
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.
§

impl<T> ErasedDestructor for T
where T: 'static,