pub trait FileHeader: Debug + Pod {
type Word: Into<u64>;
type Sword: Into<i64>;
type Endian: Endian;
type ProgramHeader: ProgramHeader<Elf = Self, Endian = Self::Endian, Word = Self::Word>;
type SectionHeader: SectionHeader<Elf = Self, Endian = Self::Endian, Word = Self::Word>;
type CompressionHeader: CompressionHeader<Endian = Self::Endian, Word = Self::Word>;
type NoteHeader: NoteHeader<Endian = Self::Endian>;
type Dyn: Dyn<Endian = Self::Endian, Word = Self::Word>;
type Sym: Sym<Endian = Self::Endian, Word = Self::Word>;
type Rel: Rel<Endian = Self::Endian, Word = Self::Word>;
type Rela: Rela<Endian = Self::Endian, Word = Self::Word> + From<Self::Rel>;
Show 33 methods
// Required methods
fn is_type_64(&self) -> bool;
fn is_type_64_sized() -> bool
where Self: Sized;
fn e_ident(&self) -> &Ident;
fn e_type(&self, endian: Self::Endian) -> u16;
fn e_machine(&self, endian: Self::Endian) -> u16;
fn e_version(&self, endian: Self::Endian) -> u32;
fn e_entry(&self, endian: Self::Endian) -> Self::Word;
fn e_phoff(&self, endian: Self::Endian) -> Self::Word;
fn e_shoff(&self, endian: Self::Endian) -> Self::Word;
fn e_flags(&self, endian: Self::Endian) -> u32;
fn e_ehsize(&self, endian: Self::Endian) -> u16;
fn e_phentsize(&self, endian: Self::Endian) -> u16;
fn e_phnum(&self, endian: Self::Endian) -> u16;
fn e_shentsize(&self, endian: Self::Endian) -> u16;
fn e_shnum(&self, endian: Self::Endian) -> u16;
fn e_shstrndx(&self, endian: Self::Endian) -> u16;
// Provided methods
fn parse<'data, R: ReadRef<'data>>(data: R) -> Result<&'data Self> { ... }
fn is_supported(&self) -> bool { ... }
fn is_class_32(&self) -> bool { ... }
fn is_class_64(&self) -> bool { ... }
fn is_little_endian(&self) -> bool { ... }
fn is_big_endian(&self) -> bool { ... }
fn endian(&self) -> Result<Self::Endian> { ... }
fn section_0<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<Option<&'data Self::SectionHeader>> { ... }
fn phnum<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<usize> { ... }
fn shnum<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<usize> { ... }
fn shstrndx<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<u32> { ... }
fn program_headers<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<&'data [Self::ProgramHeader]> { ... }
fn section_headers<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<&'data [Self::SectionHeader]> { ... }
fn section_strings_index<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<SectionIndex> { ... }
fn section_strings<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
sections: &[Self::SectionHeader],
) -> Result<StringTable<'data, R>> { ... }
fn sections<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<SectionTable<'data, Self, R>> { ... }
fn is_mips64el(&self, endian: Self::Endian) -> bool { ... }
}
Expand description
A trait for generic access to elf::FileHeader32
and elf::FileHeader64
.
Required Associated Types§
type Word: Into<u64>
type Sword: Into<i64>
type Endian: Endian
type ProgramHeader: ProgramHeader<Elf = Self, Endian = Self::Endian, Word = Self::Word>
type SectionHeader: SectionHeader<Elf = Self, Endian = Self::Endian, Word = Self::Word>
type CompressionHeader: CompressionHeader<Endian = Self::Endian, Word = Self::Word>
type NoteHeader: NoteHeader<Endian = Self::Endian>
type Dyn: Dyn<Endian = Self::Endian, Word = Self::Word>
type Sym: Sym<Endian = Self::Endian, Word = Self::Word>
type Rel: Rel<Endian = Self::Endian, Word = Self::Word>
type Rela: Rela<Endian = Self::Endian, Word = Self::Word> + From<Self::Rel>
Required Methods§
sourcefn is_type_64(&self) -> bool
fn is_type_64(&self) -> bool
Return true if this type is a 64-bit header.
This is a property of the type, not a value in the header data.
sourcefn is_type_64_sized() -> boolwhere
Self: Sized,
fn is_type_64_sized() -> boolwhere
Self: Sized,
Return true if this type is a 64-bit header.
This is a property of the type, not a value in the header data.
This is the same as Self::is_type_64
, but is non-dispatchable.
fn e_ident(&self) -> &Ident
fn e_type(&self, endian: Self::Endian) -> u16
fn e_machine(&self, endian: Self::Endian) -> u16
fn e_version(&self, endian: Self::Endian) -> u32
fn e_entry(&self, endian: Self::Endian) -> Self::Word
fn e_phoff(&self, endian: Self::Endian) -> Self::Word
fn e_shoff(&self, endian: Self::Endian) -> Self::Word
fn e_flags(&self, endian: Self::Endian) -> u32
fn e_ehsize(&self, endian: Self::Endian) -> u16
fn e_phentsize(&self, endian: Self::Endian) -> u16
fn e_phnum(&self, endian: Self::Endian) -> u16
fn e_shentsize(&self, endian: Self::Endian) -> u16
fn e_shnum(&self, endian: Self::Endian) -> u16
fn e_shstrndx(&self, endian: Self::Endian) -> u16
Provided Methods§
sourcefn parse<'data, R: ReadRef<'data>>(data: R) -> Result<&'data Self>
fn parse<'data, R: ReadRef<'data>>(data: R) -> Result<&'data Self>
Read the file header.
Also checks that the ident field in the file header is a supported format.
sourcefn is_supported(&self) -> bool
fn is_supported(&self) -> bool
Check that the ident field in the file header is a supported format.
This checks the magic number, version, class, and endianness.
fn is_class_32(&self) -> bool
fn is_class_64(&self) -> bool
fn is_little_endian(&self) -> bool
fn is_big_endian(&self) -> bool
fn endian(&self) -> Result<Self::Endian>
sourcefn section_0<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<Option<&'data Self::SectionHeader>>
fn section_0<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<Option<&'data Self::SectionHeader>>
Return the first section header, if present.
Section 0 is a special case because getting the section headers normally
requires shnum
, but shnum
may be in the first section header.
sourcefn phnum<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<usize>
fn phnum<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<usize>
Return the e_phnum
field of the header. Handles extended values.
Returns Err
for invalid values.
sourcefn shnum<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<usize>
fn shnum<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<usize>
Return the e_shnum
field of the header. Handles extended values.
Returns Err
for invalid values.
sourcefn shstrndx<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<u32>
fn shstrndx<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<u32>
Return the e_shstrndx
field of the header. Handles extended values.
Returns Err
for invalid values (including if the index is 0).
sourcefn program_headers<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<&'data [Self::ProgramHeader]>
fn program_headers<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<&'data [Self::ProgramHeader]>
Return the slice of program headers.
Returns Ok(&[])
if there are no program headers.
Returns Err
for invalid values.
sourcefn section_headers<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<&'data [Self::SectionHeader]>
fn section_headers<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<&'data [Self::SectionHeader]>
Return the slice of section headers.
Returns Ok(&[])
if there are no section headers.
Returns Err
for invalid values.
sourcefn section_strings_index<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<SectionIndex>
fn section_strings_index<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<SectionIndex>
Get the section index of the section header string table.
Returns Err
for invalid values (including if the index is 0).
sourcefn section_strings<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
sections: &[Self::SectionHeader],
) -> Result<StringTable<'data, R>>
fn section_strings<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, sections: &[Self::SectionHeader], ) -> Result<StringTable<'data, R>>
Return the string table for the section headers.
sourcefn sections<'data, R: ReadRef<'data>>(
&self,
endian: Self::Endian,
data: R,
) -> Result<SectionTable<'data, Self, R>>
fn sections<'data, R: ReadRef<'data>>( &self, endian: Self::Endian, data: R, ) -> Result<SectionTable<'data, Self, R>>
Return the section table.
sourcefn is_mips64el(&self, endian: Self::Endian) -> bool
fn is_mips64el(&self, endian: Self::Endian) -> bool
Returns whether this is a mips64el elf file.