Struct tar::Header
[−]
[src]
#[repr(C)]pub struct Header { /* fields omitted */ }
Representation of the header of an entry in an archive
Methods
impl Header
[src]
fn new_gnu() -> Header
[src]
Creates a new blank GNU header.
The GNU style header is the default for this library and allows various extensions such as long path names, long link names, and setting the atime/ctime metadata attributes of files.
fn new_ustar() -> Header
[src]
Creates a new blank UStar header.
The UStar style header is an extension of the original archive header which enables some extra metadata along with storing a longer (but not too long) path name.
UStar is also the basis used for pax archives.
fn new_old() -> Header
[src]
Creates a new blank old header.
This header format is the original archive header format which all other versions are compatible with (e.g. they are a superset). This header format limits the path name limit and isn't able to contain extra metadata like atime/ctime.
fn as_old(&self) -> &OldHeader
[src]
View this archive header as a raw "old" archive header.
This view will always succeed as all archive header formats will fill out at least the fields specified in the old header format.
fn as_old_mut(&mut self) -> &mut OldHeader
[src]
Same as as_old
, but the mutable version.
fn as_ustar(&self) -> Option<&UstarHeader>
[src]
View this archive header as a raw UStar archive header.
The UStar format is an extension to the tar archive format which enables longer pathnames and a few extra attributes such as the group and user name.
This cast may not succeed as this function will test whether the
magic/version fields of the UStar format have the appropriate values,
returning None
if they aren't correct.
fn as_ustar_mut(&mut self) -> Option<&mut UstarHeader>
[src]
Same as as_ustar_mut
, but the mutable version.
fn as_gnu(&self) -> Option<&GnuHeader>
[src]
View this archive header as a raw GNU archive header.
The GNU format is an extension to the tar archive format which enables longer pathnames and a few extra attributes such as the group and user name.
This cast may not succeed as this function will test whether the
magic/version fields of the GNU format have the appropriate values,
returning None
if they aren't correct.
fn as_gnu_mut(&mut self) -> Option<&mut GnuHeader>
[src]
Same as as_gnu
, but the mutable version.
fn as_bytes(&self) -> &[u8; 512]
[src]
Returns a view into this header as a byte array.
fn as_mut_bytes(&mut self) -> &mut [u8; 512]
[src]
Returns a view into this header as a byte array.
fn set_metadata(&mut self, meta: &Metadata)
[src]
Blanket sets the metadata in this header from the metadata argument provided.
This is useful for initializing a Header
from the OS's metadata from a
file. By default, this will use HeaderMode::Complete
to include all
metadata.
fn set_metadata_in_mode(&mut self, meta: &Metadata, mode: HeaderMode)
[src]
Sets only the metadata relevant to the given HeaderMode in this header from the metadata argument provided.
fn entry_size(&self) -> Result<u64>
[src]
Returns the size of entry's data this header represents.
This is different from Header::size
for sparse files, which have
some longer size()
but shorter entry_size()
. The entry_size()
listed here should be the number of bytes in the archive this header
describes.
May return an error if the field is corrupted.
fn size(&self) -> Result<u64>
[src]
Returns the file size this header represents.
May return an error if the field is corrupted.
fn set_size(&mut self, size: u64)
[src]
Encodes the size
argument into the size field of this header.
fn path(&self) -> Result<Cow<Path>>
[src]
Returns the raw path name stored in this header.
This method may fail if the pathname is not valid unicode and this is called on a Windows platform.
Note that this function will convert any \
characters to directory
separators.
fn path_bytes(&self) -> Cow<[u8]>
[src]
Returns the pathname stored in this header as a byte array.
This function is guaranteed to succeed, but you may wish to call the
path
method to convert to a Path
.
Note that this function will convert any \
characters to directory
separators.
fn set_path<P: AsRef<Path>>(&mut self, p: P) -> Result<()>
[src]
Sets the path name for this header.
This function will set the pathname listed in this header, encoding it in the appropriate format. May fail if the path is too long or if the path specified is not unicode and this is a Windows platform.
fn link_name(&self) -> Result<Option<Cow<Path>>>
[src]
Returns the link name stored in this header, if any is found.
This method may fail if the pathname is not valid unicode and this is
called on a Windows platform. Ok(None)
being returned, however,
indicates that the link name was not present.
Note that this function will convert any \
characters to directory
separators.
fn link_name_bytes(&self) -> Option<Cow<[u8]>>
[src]
Returns the link name stored in this header as a byte array, if any.
This function is guaranteed to succeed, but you may wish to call the
link_name
method to convert to a Path
.
Note that this function will convert any \
characters to directory
separators.
fn set_link_name<P: AsRef<Path>>(&mut self, p: P) -> Result<()>
[src]
Sets the path name for this header.
This function will set the pathname listed in this header, encoding it in the appropriate format. May fail if the path is too long or if the path specified is not unicode and this is a Windows platform.
fn mode(&self) -> Result<u32>
[src]
Returns the mode bits for this file
May return an error if the field is corrupted.
fn set_mode(&mut self, mode: u32)
[src]
Encodes the mode
provided into this header.
fn uid(&self) -> Result<u32>
[src]
Returns the value of the owner's user ID field
May return an error if the field is corrupted.
fn set_uid(&mut self, uid: u32)
[src]
Encodes the uid
provided into this header.
fn gid(&self) -> Result<u32>
[src]
Returns the value of the group's user ID field
fn set_gid(&mut self, gid: u32)
[src]
Encodes the gid
provided into this header.
fn mtime(&self) -> Result<u64>
[src]
Returns the last modification time in Unix time format
fn set_mtime(&mut self, mtime: u64)
[src]
Encodes the mtime
provided into this header.
Note that this time is typically a number of seconds passed since January 1, 1970.
fn username(&self) -> Result<Option<&str>, Utf8Error>
[src]
Return the user name of the owner of this file.
A return value of Ok(Some(..))
indicates that the user name was
present and was valid utf-8, Ok(None)
indicates that the user name is
not present in this archive format, and Err
indicates that the user
name was present but was not valid utf-8.
fn username_bytes(&self) -> Option<&[u8]>
[src]
Returns the user name of the owner of this file, if present.
A return value of None
indicates that the user name is not present in
this header format.
fn set_username(&mut self, name: &str) -> Result<()>
[src]
Sets the username inside this header.
This function will return an error if this header format cannot encode a user name or the name is too long.
fn groupname(&self) -> Result<Option<&str>, Utf8Error>
[src]
Return the group name of the owner of this file.
A return value of Ok(Some(..))
indicates that the group name was
present and was valid utf-8, Ok(None)
indicates that the group name is
not present in this archive format, and Err
indicates that the group
name was present but was not valid utf-8.
fn groupname_bytes(&self) -> Option<&[u8]>
[src]
Returns the group name of the owner of this file, if present.
A return value of None
indicates that the group name is not present in
this header format.
fn set_groupname(&mut self, name: &str) -> Result<()>
[src]
Sets the group name inside this header.
This function will return an error if this header format cannot encode a group name or the name is too long.
fn device_major(&self) -> Result<Option<u32>>
[src]
Returns the device major number, if present.
This field may not be present in all archives, and it may not be
correctly formed in all archives. Ok(Some(..))
means it was present
and correctly decoded, Ok(None)
indicates that this header format does
not include the device major number, and Err
indicates that it was
present and failed to decode.
fn set_device_major(&mut self, major: u32) -> Result<()>
[src]
Encodes the value major
into the dev_major field of this header.
This function will return an error if this header format cannot encode a major device number.
fn device_minor(&self) -> Result<Option<u32>>
[src]
Returns the device minor number, if present.
This field may not be present in all archives, and it may not be
correctly formed in all archives. Ok(Some(..))
means it was present
and correctly decoded, Ok(None)
indicates that this header format does
not include the device minor number, and Err
indicates that it was
present and failed to decode.
fn set_device_minor(&mut self, minor: u32) -> Result<()>
[src]
Encodes the value minor
into the dev_minor field of this header.
This function will return an error if this header format cannot encode a minor device number.
fn entry_type(&self) -> EntryType
[src]
Returns the type of file described by this header.
fn set_entry_type(&mut self, ty: EntryType)
[src]
Sets the type of file that will be described by this header.
fn cksum(&self) -> Result<u32>
[src]
Returns the checksum field of this header.
May return an error if the field is corrupted.
fn set_cksum(&mut self)
[src]
Sets the checksum field of this header based on the current fields in this header.