[−][src]Trait object::read::ObjectSection
A section defined in an object file.
Associated Types
type RelocationIterator: Iterator<Item = (u64, Relocation)>
An iterator over the relocations for a section.
The first field in the item tuple is the section offset that the relocation applies to.
Required methods
fn index(&self) -> SectionIndex
Returns the section index.
fn address(&self) -> u64
Returns the address of the section.
fn size(&self) -> u64
Returns the size of the section in memory.
fn align(&self) -> u64
Returns the alignment of the section in memory.
fn file_range(&self) -> Option<(u64, u64)>
Returns offset and size of on-disk segment (if any).
fn data(&self) -> Result<&'data [u8]>
Returns the raw contents of the section.
The length of this data may be different from the size of the section in memory.
This does not do any decompression.
fn data_range(&self, address: u64, size: u64) -> Result<Option<&'data [u8]>>
Return the raw contents of the section data in the given range.
This does not do any decompression.
Returns Ok(None)
if the section does not contain the given range.
fn compressed_data(&self) -> Result<CompressedData<'data>>
Returns the potentially compressed contents of the section, along with information about the compression.
fn name(&self) -> Result<&str>
Returns the name of the section.
fn segment_name(&self) -> Result<Option<&str>>
Returns the name of the segment for this section.
fn kind(&self) -> SectionKind
Return the kind of this section.
fn relocations(&self) -> Self::RelocationIterator
Get the relocations for this section.
fn flags(&self) -> SectionFlags
Section flags that are specific to each file format.
Provided methods
fn uncompressed_data(&self) -> Result<Cow<'data, [u8]>>
Returns the uncompressed contents of the section.
The length of this data may be different from the size of the section in memory.
If no compression is detected, then returns the data unchanged.
Returns Err
if decompression fails.