Struct TarballEntry

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

An entry in a tarball.

Fields§

§path: PathBuf

The path of the entry in the archive.

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

The raw tar entry.

Implementations§

Source§

impl<'a, 'c> TarballEntry<'a, 'c>

Source

pub fn path(&self) -> &Path

Returns the path of the entry in the archive.

Source

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

Returns the content of the entry.

§Errors

Returns an error if Entry::read_to_end fails.

Source

pub fn is_dir(&self) -> bool

Checks whether the TarballEntry represents a directory.

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

§Note

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

Source

pub fn is_file(&self) -> bool

Checks whether the TarballEntry represents a regular file.

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

§Note

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

Checks whether the TarballEntry represents a symlink.

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

§Note

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

Source

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

Returns the access permissions that apply for the TarballEntry.

§Notes
  • This is a convenience method for retrieving the mode of the Entry::header contained in the TarballEntry.
  • 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 raw(&self) -> &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 TarballEntry<'_, '_>

Source§

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

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

impl Read for TarballEntry<'_, '_>

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 TarballEntry<'a, 'c>

§

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

§

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

§

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

§

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

§

impl<'a, 'c> !UnwindSafe for TarballEntry<'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,