Struct gimli::read::DebugAranges
source · pub struct DebugAranges<R> { /* private fields */ }
Expand description
The DebugAranges
struct represents the DWARF address range information
found in the .debug_aranges
section.
Implementations§
source§impl<'input, Endian> DebugAranges<EndianSlice<'input, Endian>>where
Endian: Endianity,
impl<'input, Endian> DebugAranges<EndianSlice<'input, Endian>>where
Endian: Endianity,
sourcepub fn new(section: &'input [u8], endian: Endian) -> Self
pub fn new(section: &'input [u8], endian: Endian) -> Self
Construct a new DebugAranges
instance from the data in the .debug_aranges
section.
It is the caller’s responsibility to read the .debug_aranges
section and
present it as a &[u8]
slice. That means using some ELF loader on
Linux, a Mach-O loader on macOS, etc.
use gimli::{DebugAranges, LittleEndian};
let debug_aranges =
DebugAranges::new(read_debug_aranges_section(), LittleEndian);
source§impl<R: Reader> DebugAranges<R>
impl<R: Reader> DebugAranges<R>
sourcepub fn headers(&self) -> ArangeHeaderIter<R>
pub fn headers(&self) -> ArangeHeaderIter<R>
Iterate the sets of entries in the .debug_aranges
section.
Each set of entries belongs to a single unit.
sourcepub fn header(
&self,
offset: DebugArangesOffset<R::Offset>
) -> Result<ArangeHeader<R>>
pub fn header(
&self,
offset: DebugArangesOffset<R::Offset>
) -> Result<ArangeHeader<R>>
Get the header at the given offset.
source§impl<T> DebugAranges<T>
impl<T> DebugAranges<T>
sourcepub fn borrow<'a, F, R>(&'a self, borrow: F) -> DebugAranges<R>where
F: FnMut(&'a T) -> R,
pub fn borrow<'a, F, R>(&'a self, borrow: F) -> DebugAranges<R>where
F: FnMut(&'a T) -> R,
Create a DebugAranges
section that references the data in self
.
This is useful when R
implements Reader
but T
does not.
Example Usage
// Read the DWARF section into a `Vec` with whatever object loader you're using.
let owned_section: gimli::DebugAranges<Vec<u8>> = load_section();
// Create a reference to the DWARF section.
let section = owned_section.borrow(|section| {
gimli::EndianSlice::new(§ion, gimli::LittleEndian)
});
Trait Implementations§
source§impl<R: Clone> Clone for DebugAranges<R>
impl<R: Clone> Clone for DebugAranges<R>
source§fn clone(&self) -> DebugAranges<R>
fn clone(&self) -> DebugAranges<R>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<R: Debug> Debug for DebugAranges<R>
impl<R: Debug> Debug for DebugAranges<R>
source§impl<R: Default> Default for DebugAranges<R>
impl<R: Default> Default for DebugAranges<R>
source§fn default() -> DebugAranges<R>
fn default() -> DebugAranges<R>
Returns the “default value” for a type. Read more
source§impl<R> From<R> for DebugAranges<R>
impl<R> From<R> for DebugAranges<R>
source§impl<R> Section<R> for DebugAranges<R>
impl<R> Section<R> for DebugAranges<R>
source§fn section_name() -> &'static str
fn section_name() -> &'static str
Returns the ELF section name for this type.