[−][src]Struct gimli::read::DebugLine
The DebugLine
struct contains the source location to instruction mapping
found in the .debug_line
section.
Methods
impl<'input, Endian> DebugLine<EndianSlice<'input, Endian>> where
Endian: Endianity,
[src]
Endian: Endianity,
pub fn new(debug_line_section: &'input [u8], endian: Endian) -> Self
[src]
Construct a new DebugLine
instance from the data in the .debug_line
section.
It is the caller's responsibility to read the .debug_line
section and
present it as a &[u8]
slice. That means using some ELF loader on
Linux, a Mach-O loader on OSX, etc.
use gimli::{DebugLine, LittleEndian}; let debug_line = DebugLine::new(read_debug_line_section_somehow(), LittleEndian);
impl<R: Reader> DebugLine<R>
[src]
pub fn program(
&self,
offset: DebugLineOffset<R::Offset>,
address_size: u8,
comp_dir: Option<R>,
comp_name: Option<R>
) -> Result<IncompleteLineProgram<R>>
[src]
&self,
offset: DebugLineOffset<R::Offset>,
address_size: u8,
comp_dir: Option<R>,
comp_name: Option<R>
) -> Result<IncompleteLineProgram<R>>
Parse the line number program whose header is at the given offset
in the
.debug_line
section.
The address_size
must match the compilation unit that the lines apply to.
The comp_dir
should be from the DW_AT_comp_dir
attribute of the compilation
unit. The comp_name
should be from the DW_AT_name
attribute of the
compilation unit.
use gimli::{DebugLine, DebugLineOffset, IncompleteLineProgram, EndianSlice, LittleEndian}; let debug_line = DebugLine::new(read_debug_line_section_somehow(), LittleEndian); // In a real example, we'd grab the offset via a compilation unit // entry's `DW_AT_stmt_list` attribute, and the address size from that // unit directly. let offset = DebugLineOffset(0); let address_size = 8; let program = debug_line.program(offset, address_size, None, None) .expect("should have found a header at that offset, and parsed it OK");
impl<T> DebugLine<T>
[src]
pub fn borrow<'a, F, R>(&'a self, borrow: F) -> DebugLine<R> where
F: FnMut(&'a T) -> R,
[src]
F: FnMut(&'a T) -> R,
Create a DebugLine
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::DebugLine<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
impl<R> Section<R> for DebugLine<R>
[src]
fn id() -> SectionId
[src]
fn reader(&self) -> &R
[src]
fn section_name() -> &'static str
[src]
Returns the ELF section name for this type.
fn load<F, E>(f: F) -> Result<Self, E> where
F: FnOnce(SectionId) -> Result<R, E>,
[src]
F: FnOnce(SectionId) -> Result<R, E>,
Try to load the section using the given loader function.
fn lookup_offset_id(&self, id: ReaderOffsetId) -> Option<(SectionId, R::Offset)> where
R: Reader,
[src]
R: Reader,
Returns the Reader
for this section.
impl<R: Copy> Copy for DebugLine<R>
[src]
impl<R: Debug> Debug for DebugLine<R>
[src]
impl<R> From<R> for DebugLine<R>
[src]
impl<R: Clone> Clone for DebugLine<R>
[src]
fn clone(&self) -> DebugLine<R>
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl<R: Default> Default for DebugLine<R>
[src]
Auto Trait Implementations
impl<R> Send for DebugLine<R> where
R: Send,
R: Send,
impl<R> Sync for DebugLine<R> where
R: Sync,
R: Sync,
impl<R> Unpin for DebugLine<R> where
R: Unpin,
R: Unpin,
impl<R> UnwindSafe for DebugLine<R> where
R: UnwindSafe,
R: UnwindSafe,
impl<R> RefUnwindSafe for DebugLine<R> where
R: RefUnwindSafe,
R: RefUnwindSafe,
Blanket Implementations
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> From<T> for T
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,