Struct gimli::read::LocationLists

source ·
pub struct LocationLists<R> { /* private fields */ }
Expand description

The DWARF data found in .debug_loc and .debug_loclists sections.

Implementations§

source§

impl<R> LocationLists<R>

source

pub fn new( debug_loc: DebugLoc<R>, debug_loclists: DebugLocLists<R>, ) -> LocationLists<R>

Construct a new LocationLists instance from the data in the .debug_loc and .debug_loclists sections.

source§

impl<T> LocationLists<T>

source

pub fn borrow<'a, F, R>(&'a self, borrow: F) -> LocationLists<R>
where F: FnMut(&'a T) -> R,

Create a LocationLists 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::LocationLists<Vec<u8>> = load_section();
// Create a reference to the DWARF section.
let section = owned_section.borrow(|section| {
    gimli::EndianSlice::new(&section, gimli::LittleEndian)
});
source§

impl<R: Reader> LocationLists<R>

source

pub fn locations( &self, offset: LocationListsOffset<R::Offset>, unit_encoding: Encoding, base_address: u64, debug_addr: &DebugAddr<R>, debug_addr_base: DebugAddrBase<R::Offset>, ) -> Result<LocListIter<R>>

Iterate over the LocationListEntrys starting at the given offset.

The unit_encoding must match the compilation unit that the offset was contained in.

The base_address should be obtained from the DW_AT_low_pc attribute in the DW_TAG_compile_unit entry for the compilation unit that contains this location list.

Can be used with FallibleIterator.

source

pub fn locations_dwo( &self, offset: LocationListsOffset<R::Offset>, unit_encoding: Encoding, base_address: u64, debug_addr: &DebugAddr<R>, debug_addr_base: DebugAddrBase<R::Offset>, ) -> Result<LocListIter<R>>

Similar to locations, but with special handling for .dwo files. This should only been used when this LocationLists was loaded from a .dwo file.

source

pub fn raw_locations( &self, offset: LocationListsOffset<R::Offset>, unit_encoding: Encoding, ) -> Result<RawLocListIter<R>>

Iterate over the raw LocationListEntrys starting at the given offset.

The unit_encoding must match the compilation unit that the offset was contained in.

This iterator does not perform any processing of the location entries, such as handling base addresses.

Can be used with FallibleIterator.

source

pub fn raw_locations_dwo( &self, offset: LocationListsOffset<R::Offset>, unit_encoding: Encoding, ) -> Result<RawLocListIter<R>>

Similar to raw_locations, but with special handling for .dwo files. This should only been used when this LocationLists was loaded from a .dwo file.

source

pub fn get_offset( &self, unit_encoding: Encoding, base: DebugLocListsBase<R::Offset>, index: DebugLocListsIndex<R::Offset>, ) -> Result<LocationListsOffset<R::Offset>>

Returns the .debug_loclists offset at the given base and index.

The base must be the DW_AT_loclists_base value from the compilation unit DIE. This is an offset that points to the first entry following the header.

The index is the value of a DW_FORM_loclistx attribute.

source

pub fn lookup_offset_id( &self, id: ReaderOffsetId, ) -> Option<(SectionId, R::Offset)>

Call Reader::lookup_offset_id for each section, and return the first match.

Trait Implementations§

source§

impl<R: Clone> Clone for LocationLists<R>

source§

fn clone(&self) -> LocationLists<R>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<R: Debug> Debug for LocationLists<R>

source§

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

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

impl<R: Default> Default for LocationLists<R>

source§

fn default() -> LocationLists<R>

Returns the “default value” for a type. Read more
source§

impl<R: Copy> Copy for LocationLists<R>

Auto Trait Implementations§

§

impl<R> Freeze for LocationLists<R>
where R: Freeze,

§

impl<R> RefUnwindSafe for LocationLists<R>
where R: RefUnwindSafe,

§

impl<R> Send for LocationLists<R>
where R: Send,

§

impl<R> Sync for LocationLists<R>
where R: Sync,

§

impl<R> Unpin for LocationLists<R>
where R: Unpin,

§

impl<R> UnwindSafe for LocationLists<R>
where R: UnwindSafe,

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> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> CloneToUninit for T
where T: Copy,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

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>,

§

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.