#[repr(C, align(8))]pub struct ElfSectionsTag { /* private fields */ }
Expand description
This tag contains the section header table from an ELF binary.
Implementations§
Source§impl ElfSectionsTag
impl ElfSectionsTag
Sourcepub fn new(
number_of_sections: u32,
entry_size: u32,
shndx: u32,
sections: &[u8],
) -> Box<Self>
pub fn new( number_of_sections: u32, entry_size: u32, shndx: u32, sections: &[u8], ) -> Box<Self>
Create a new ElfSectionsTag with the given data.
Sourcepub const fn sections(&self) -> ElfSectionIter<'_> ⓘ
pub const fn sections(&self) -> ElfSectionIter<'_> ⓘ
Get an iterator over the ELF sections.
Sourcepub const fn number_of_sections(&self) -> u32
pub const fn number_of_sections(&self) -> u32
Returns the amount of sections.
Sourcepub const fn entry_size(&self) -> u32
pub const fn entry_size(&self) -> u32
Returns the size of each entry.
Trait Implementations§
Source§impl Debug for ElfSectionsTag
impl Debug for ElfSectionsTag
Source§impl MaybeDynSized for ElfSectionsTag
impl MaybeDynSized for ElfSectionsTag
Source§const BASE_SIZE: usize = 20usize
const BASE_SIZE: usize = 20usize
The true base size of the struct without any implicit or additional
padding. Note that
size_of::<T>()
isn’t sufficient, as for example
the type could have three u32
fields, which would add an implicit
u32
padding. However, this constant must always fulfill
BASE_SIZE >= size_of::<Self::Header>()
. Read moreSource§fn dst_len(header: &TagHeader) -> usize
fn dst_len(header: &TagHeader) -> usize
Returns the amount of items in the dynamically sized portion of the
DST. Note that this is not the amount of bytes. So if the dynamically
sized portion is 16 bytes in size and each element is 4 bytes big, then
this function must return 4. Read more
Source§fn payload(&self) -> &[u8]
fn payload(&self) -> &[u8]
Returns the payload, i.e., all memory that is not occupied by the
Header
of the type.