16#ifndef LIEF_MACHO_BINARY_H
17#define LIEF_MACHO_BINARY_H
54class CodeSignatureDir;
56class DyldChainedFixups;
62class DynamicSymbolCommand;
66class FunctionVariants;
67class FunctionVariantFixups;
68class LazyLoadDylibInfo;
70class IndirectBindingInfo;
79class SegmentSplitInfo;
114 using commands_t = std::vector<std::unique_ptr<LoadCommand>>;
284 return const_cast<Symbol*
>(
static_cast<const Binary*
>(
this)->get_symbol(name));
292 return {symbols_, [](
const std::unique_ptr<Symbol>& symbol) {
297 return {symbols_, [](
const std::unique_ptr<Symbol>& symbol) {
307 return {symbols_, [](
const std::unique_ptr<Symbol>& symbol) {
313 return {symbols_, [](
const std::unique_ptr<Symbol>& symbol) {
330 return lazy_load_dylib_infos_;
334 return lazy_load_dylib_infos_;
363 void write(const std::
string& filename);
387 std::vector<uint8_t>
raw();
430 static_cast<const Binary*
>(
this)->find_library(name)
507 static_cast<const Binary*
>(
this)->get_section(name)
521 static_cast<const Binary*
>(
this)->get_section(segname, secname)
540 static_cast<const Binary*
>(
this)->get_segment(name)
566 static_cast<const Binary*
>(
this)->section_from_offset(offset)
576 static_cast<const Binary*
>(
this)->section_from_virtual_address(
582 uint64_t virtual_address
594 uint64_t slide = 0)
const override;
601 static_cast<const Binary*
>(
this)->segment_from_offset(offset)
620 static_cast<const Binary*
>(
this)->segment_from_virtual_address(
626 uint64_t virtual_address
642 return r.
start <= address && address < r.
end;
648 std::ostream&
print(std::ostream& os)
const override;
656 void patch_address(uint64_t address,
const std::vector<uint8_t>& patch_value,
668 uint64_t address, uint64_t patch_value,
size_t size =
sizeof(uint64_t),
674 uint64_t virtual_address, uint64_t size,
710 return uuid() !=
nullptr;
791 return rpath() !=
nullptr;
828 static_cast<const Binary*
>(
this)->code_signature()
841 static_cast<const Binary*
>(
this)->code_signature_dir()
953 static_cast<const Binary*
>(
this)->two_level_hints()
966 static_cast<const Binary*
>(
this)->linker_opt_hint()
998 return const_cast<AtomInfo*
>(
static_cast<const Binary*
>(
this)->atom_info());
1020 static_cast<const Binary*
>(
this)->function_variants()
1034 static_cast<const Binary*
>(
this)->function_variant_fixups()
1052 template<
class CMD,
class Func>
1073 return !filesets_.empty();
1079 return fileset_info_.name;
1084 return fileset_info_.address;
1104 return in_memory_base_addr_;
1136 LIEF_LOCAL size_t available_command_space()
const {
1137 return available_command_space_;
1144 LIEF_LOCAL void shift_command(
size_t width, uint64_t from_offset);
1162 get_abstract_exported_functions()
const override;
1164 get_abstract_imported_functions()
const override;
1166 get_abstract_imported_libraries()
const override;
1171 ok_error_t ensure_command_space(
size_t size) {
1172 return available_command_space_ < size ? shift(size) :
ok();
1175 relocations_t& relocations_list() {
1176 return this->relocations_;
1179 const relocations_t& relocations_list()
const {
1180 return this->relocations_;
1183 size_t pointer_size()
const {
1184 return this->is64_ ?
sizeof(uint64_t) : sizeof(uint32_t);
1189 commands_t commands_;
1193 libraries_cache_t libraries_;
1196 lazy_load_dylib_info_cache_t lazy_load_dylib_infos_;
1200 sections_cache_t sections_;
1203 segments_cache_t segments_;
1205 fileset_binaries_t filesets_;
1208 mutable relocations_t relocations_;
1209 size_t available_command_space_ = 0;
1213 std::map<uint64_t, SegmentCommand*> offset_seg_;
1216 struct fileset_info_t {
1218 uint64_t address = 0;
1221 uint64_t fat_offset_ = 0;
1222 uint64_t in_memory_base_addr_ = 0;
1223 std::vector<uint8_t> overlay_;
1224 std::vector<std::unique_ptr<IndirectBindingInfo>> indirect_bindings_;
1225 fileset_info_t fileset_info_;
1226 mutable std::mutex mu_;
Generic interface representing a binary executable.
Definition Abstract/Binary.hpp:60
std::vector< Function > functions_t
Definition Abstract/Binary.hpp:83
@ MACHO
Definition Abstract/Binary.hpp:79
FORMATS format() const
Executable format (ELF, PE, Mach-O) of the underlying binary.
Definition Abstract/Binary.hpp:125
std::vector< Symbol * > symbols_t
Internal container.
Definition Abstract/Binary.hpp:95
VA_TYPES
Enumeration of virtual address types used for patching and memory access.
Definition Abstract/Binary.hpp:63
@ AUTO
Automatically determine if the address is absolute or relative (default behavior).
Definition Abstract/Binary.hpp:66
std::vector< Section * > sections_t
Internal container.
Definition Abstract/Binary.hpp:86
virtual uint64_t page_size() const
Get the default memory page size according to the architecture and the format of the current binary.
std::vector< Relocation * > relocations_t
Internal container.
Definition Abstract/Binary.hpp:104
Class which represents the LC_ATOM_INFO command.
Definition AtomInfo.hpp:36
Class which represents a MachO binary.
Definition MachO/Binary.hpp:91
Symbol * add_local_symbol(uint64_t address, const std::string &name)
Add a symbol in LC_SYMTAB command of the current binary.
UUIDCommand * uuid()
Return the MachO::UUIDCommand if present, a nullptr otherwise.
bool has_build_version() const
true if the binary has the BuildVersion command.
Definition MachO/Binary.hpp:898
std::vector< uint8_t > raw()
Reconstruct the binary object and return its content as bytes.
size_t count_commands() const
static bool classof(const LIEF::Binary *bin)
Definition MachO/Binary.hpp:1121
const_filter_iterator< const commands_t &, const RPathCommand * > it_const_rpaths
Iterator which outputs const RPathCommand&.
Definition MachO/Binary.hpp:212
bool is_pie() const override
Check if the binary is position independent.
Definition MachO/Binary.hpp:682
uint64_t fileset_addr() const
Original address associated with the LC_FILESET_ENTRY for this MachO.
Definition MachO/Binary.hpp:1083
bool has_function_starts() const
true if the binary has a MachO::FunctionStarts command.
Definition MachO/Binary.hpp:745
uint64_t entrypoint() const override
The binary entrypoint.
bool has_segment_split_info() const
true if the binary has segment split info.
Definition MachO/Binary.hpp:856
it_imported_symbols imported_symbols()
Return binary's imported symbols (iterator over LIEF::MachO::Symbol).
Definition MachO/Binary.hpp:306
Section * section_from_offset(uint64_t offset)
Return the MachO::Section that encompasses the provided offset. If a section can't be found,...
Definition MachO/Binary.hpp:564
const Section * section_from_offset(uint64_t offset) const
bool has_source_version() const
true if the binary has a MachO::SourceVersion command.
Definition MachO/Binary.hpp:754
const SegmentCommand * get_segment(const std::string &name) const
Return the segment from the given name.
bool has_function_variant_fixups() const
true if the binary has the command LC_FUNCTION_VARIANT_FIXUPS.
Definition MachO/Binary.hpp:1027
it_commands commands()
Return an iterator over the MachO LoadCommand present in the binary.
Definition MachO/Binary.hpp:249
filter_iterator< commands_t &, NoteCommand * > it_notes
Iterator which outputs NoteCommand&.
Definition MachO/Binary.hpp:228
range_t off_ranges() const
Return the range of offsets.
result< uint64_t > offset_to_virtual_address(uint64_t offset, uint64_t slide=0) const override
Convert the given offset into a virtual address.
const SegmentCommand * segment_from_virtual_address(uint64_t virtual_address) const
const_ref_iterator< const relocations_t &, const Relocation * > it_const_relocations
Iterator which outputs const Relocation&.
Definition MachO/Binary.hpp:205
range_t tlv_initial_content_range() const
Return the TLV initial content range.
result< uint64_t > virtual_address_to_offset(uint64_t virtual_address) const
Convert a virtual address to an offset in the file.
bool has_atom_info() const
true if the binary has the command LC_ATOM_INFO.
Definition MachO/Binary.hpp:992
bool has_dynamic_symbol_command() const
true if the binary has a MachO::DynamicSymbolCommand command.
Definition MachO/Binary.hpp:812
friend class BindingInfoIterator
Definition MachO/Binary.hpp:97
const_ref_iterator< const commands_t &, LoadCommand * > it_const_commands
Iterator that outputs const LoadCommand&.
Definition MachO/Binary.hpp:120
TwoLevelHints * two_level_hints()
Return the MachO::TwoLevelHints if present, a nullptr otherwise.
Definition MachO/Binary.hpp:951
bool is_valid_addr(uint64_t address) const
Check if the given address is encompassed in the binary's virtual addresses range.
Definition MachO/Binary.hpp:640
it_const_lazy_load_dylib_info lazy_load_dylib_infos() const
Definition MachO/Binary.hpp:333
filter_iterator< commands_t &, RPathCommand * > it_rpaths
Iterator which outputs RPathCommand&.
Definition MachO/Binary.hpp:209
void write(const std::string &filename)
Reconstruct the binary object and write the result in the given filename.
LoadCommand * add(const DylibCommand &library)
Insert the given DylibCommand.
it_lazy_load_dylib_info lazy_load_dylib_infos()
Return an iterator over the binary's LazyLoadDylibInfo commands (LC_LAZY_LOAD_DYLIB_INFO).
Definition MachO/Binary.hpp:329
DylinkerCommand * dylinker()
Return the MachO::DylinkerCommand if present, a nullptr otherwise.
bool has_dylinker() const
true if the binary has a MachO::DylinkerCommand.
Definition MachO/Binary.hpp:727
Section * get_section(const std::string &segname, const std::string &secname)
Return the section from the segment with the name given in the first parameter and with the section's...
Definition MachO/Binary.hpp:518
bool has_dyld_chained_fixups() const
true if the binary has the command LC_DYLD_CHAINED_FIXUPS.
Definition MachO/Binary.hpp:928
it_sub_clients subclients()
Iterator over all the MachO::SubClient commands.
bool has_dyld_info() const
true if the binary has a MachO::DyldInfo command.
Definition MachO/Binary.hpp:736
EncryptionInfo * encryption_info()
Return the MachO::EncryptionInfo if present, a nullptr otherwise.
DataInCode * data_in_code()
Return the MachO::DataInCode if present, a nullptr otherwise.
bool extend_section(Section §ion, size_t size)
Extend the content of the given Section.
const TwoLevelHints * two_level_hints() const
std::vector< DylibCommand * > libraries_cache_t
Internal container for storing Mach-O DylibCommand.
Definition MachO/Binary.hpp:164
std::string loader() const
Return the binary's loader (e.g. /usr/lib/dyld) or an empty string if the binary does not use a loade...
bool has_symbol(const std::string &name) const
Check if a symbol with the given name exists.
Definition MachO/Binary.hpp:276
BuildVersion * build_version()
Return the MachO::BuildVersion if present, a nullptr otherwise.
bool has_symbol_command() const
true if the binary has a MachO::SymbolCommand command.
Definition MachO/Binary.hpp:803
const LoadCommand * operator[](LoadCommand::TYPE type) const
Definition MachO/Binary.hpp:1058
size_t segment_index(const SegmentCommand &segment) const
Return the index of the given SegmentCommand.
bool has_rpath() const
true if the binary has a MachO::RPathCommand command.
Definition MachO/Binary.hpp:790
it_const_fileset_binaries filesets() const
Definition MachO/Binary.hpp:263
ok_error_t shift_linkedit(size_t width)
Shift the position on the __LINKEDIT data by width.
std::vector< SegmentCommand * > segments_cache_t
Internal container for storing Mach-O SegmentCommand.
Definition MachO/Binary.hpp:155
it_relocations relocations()
Return an iterator over the MachO::Relocation.
Definition MachO/Binary.hpp:354
bool extend(const LoadCommand &command, uint64_t size)
Extend the size of the given LoadCommand.
VersionMin * version_min()
Return the MachO::VersionMin command if present, a nullptr otherwise.
bool remove_signature()
Remove the LC_SIGNATURE command.
bool has_nx() const override
Check if the binary uses NX protection.
Definition MachO/Binary.hpp:687
bool can_remove(const Symbol &sym) const
Check if the given symbol can be safely removed.
it_bindings bindings() const
Return an iterator over the binding info which can come from either DyldInfo or DyldChainedFixups com...
bool has_routine_command() const
true if the binary has a MachO::Routine command.
Definition MachO/Binary.hpp:781
const FunctionVariantFixups * function_variant_fixups() const
void remove_section(const std::string &segname, const std::string &secname, bool clear=false)
Remove the section from the segment with the name given in the first parameter and with the section's...
filter_iterator< symbols_t &, Symbol * > it_imported_symbols
Iterator that outputs imported Symbol&.
Definition MachO/Binary.hpp:139
uint64_t imagebase() const override
Return the binary's imagebase. 0 if not relevant.
std::ostream & print(std::ostream &os) const override
FunctionVariants * function_variants()
Return the FunctionVariants if present, a nullptr otherwise.
Definition MachO/Binary.hpp:1018
const DylibCommand * find_library(const std::string &name) const
Try to find the library with the given library name.
bool is_macos() const
True if this binary targets macOS.
Definition MachO/Binary.hpp:921
bool disable_pie()
Remove the PIE flag.
bool can_remove_symbol(const std::string &name) const
Check if the MachO::Symbol with the given name can be safely removed.
ThreadCommand * thread_command()
Return the MachO::ThreadCommand command if present, a nullptr otherwise.
Section * section_from_virtual_address(uint64_t virtual_address)
Return the MachO::Section that encompasses the provided virtual address. If a section can't be found,...
Definition MachO/Binary.hpp:574
static bool can_cache_segment(const SegmentCommand &segment)
Check if the given segment can go in the offset_seg_ cache.
friend class BinaryParser
Definition MachO/Binary.hpp:94
bool has_segment(const std::string &name) const
Check if a segment with the given name exists.
Definition MachO/Binary.hpp:529
result< uint64_t > get_function_address(const std::string &name) const override
Try to get the address for the function's name given in parameter.
bool has_uuid() const
true if the binary has a MachO::UUIDCommand command.
Definition MachO/Binary.hpp:709
const Section * section_from_virtual_address(uint64_t virtual_address) const
bool remove_symbol(const std::string &name)
Remove the symbol with the given name.
DyldExportsTrie * dyld_exports_trie()
Return the MachO::DyldExportsTrie if present, a nullptr otherwise.
it_notes notes()
Iterator over the different LC_NOTE commands.
it_const_sections sections() const
Definition MachO/Binary.hpp:349
it_const_symbols symbols() const
Definition MachO/Binary.hpp:271
std::vector< std::unique_ptr< LoadCommand > > commands_t
Internal container for storing Mach-O LoadCommand.
Definition MachO/Binary.hpp:114
void accept(LIEF::Visitor &visitor) const override
Method so that the visitor can visit us.
bool has_dyld_exports_trie() const
true if the binary has the command LC_DYLD_EXPORTS_TRIE.
Definition MachO/Binary.hpp:937
ref_iterator< relocations_t &, Relocation * > it_relocations
Iterator which outputs Relocation&.
Definition MachO/Binary.hpp:202
bool remove(LoadCommand::TYPE type)
Remove all LoadCommand with the given type (MachO::LoadCommand::TYPE).
it_symbols symbols()
Return binary's symbols .
Definition MachO/Binary.hpp:268
std::vector< LazyLoadDylibInfo * > lazy_load_dylib_info_cache_t
Internal container for storing Mach-O LazyLoadDylibInfo.
Definition MachO/Binary.hpp:173
LoadCommand * operator[](LoadCommand::TYPE type)
Definition MachO/Binary.hpp:1055
bool has_subclients() const
bool has_linker_opt_hint() const
true if the binary has the command LC_LINKER_OPTIMIZATION_HINT.
Definition MachO/Binary.hpp:959
const_ref_iterator< const sections_cache_t & > it_const_sections
Iterator that outputs const Section&.
Definition MachO/Binary.hpp:152
ok_error_t shift(size_t value)
Shift the content located right after the Load commands table. This operation can be used to add a ne...
iterator_range< BindingInfoIterator > it_bindings
Definition MachO/Binary.hpp:222
std::vector< std::unique_ptr< Binary > > fileset_binaries_t
Internal container for storing Mach-O Fileset Binary.
Definition MachO/Binary.hpp:183
LIEF::Binary::functions_t ctor_functions() const override
Return the list of the MachO's constructors.
std::unique_ptr< objc::Metadata > objc_metadata() const
Return Objective-C metadata if present.
void refresh_seg_offset()
it_segments segments()
Return an iterator over the SegmentCommand.
Definition MachO/Binary.hpp:338
Binary(const Binary &)=delete
Section * get_section(const std::string &name)
Return the section from the given name or a nullptr if the section can't be found.
Definition MachO/Binary.hpp:505
it_fileset_binaries filesets()
Return an iterator over the MachO::Binary associated with the LoadCommand::TYPE::FILESET_ENTRY comman...
Definition MachO/Binary.hpp:259
Binary & operator=(const Binary &)=delete
filter_iterator< commands_t &, SubClient * > it_sub_clients
Iterator which outputs SubClient&.
Definition MachO/Binary.hpp:216
const FunctionVariants * function_variants() const
it_const_segments segments() const
Definition MachO/Binary.hpp:341
const_filter_iterator< const commands_t &, const NoteCommand * > it_const_notes
Iterator which outputs const NoteCommand&.
Definition MachO/Binary.hpp:231
bool has_nx_stack() const
Return True if the stack is flagged as non-executable. False otherwise.
Definition MachO/Binary.hpp:692
it_libraries libraries()
Return binary imported libraries (MachO::DylibCommand).
Definition MachO/Binary.hpp:319
bool has_data_in_code() const
true if the binary has a MachO::DataInCode command.
Definition MachO/Binary.hpp:847
const Section * get_section(const std::string &name) const
Return the section from the given name or a nullptr if the section can't be found.
static bool is_exported(const Symbol &symbol)
Check if the given symbol is exported.
Section * add_section(const Section §ion)
Add a new MachO::Section in the __TEXT segment.
const SegmentCommand * segment_from_offset(uint64_t offset) const
it_exported_symbols exported_symbols()
Return binary's exported symbols (iterator over LIEF::MachO::Symbol).
Definition MachO/Binary.hpp:291
filter_iterator< symbols_t &, Symbol * > it_exported_symbols
Iterator that outputs exported Symbol&.
Definition MachO/Binary.hpp:132
BuildVersion::PLATFORMS platform() const
Return the platform for which this Mach-O has been compiled for.
Definition MachO/Binary.hpp:907
it_const_relocations relocations() const
span< const uint8_t > overlay() const
Definition MachO/Binary.hpp:1125
SegmentCommand * segment_from_virtual_address(uint64_t virtual_address)
Return the binary's SegmentCommand which encompasses the given virtual address or a nullptr if not fo...
Definition MachO/Binary.hpp:618
friend class Builder
Definition MachO/Binary.hpp:95
DyldChainedFixups * dyld_chained_fixups()
Return the MachO::DyldChainedFixups if present, a nullptr otherwise.
const CodeSignature * code_signature() const
const_ref_iterator< const symbols_t &, const Symbol * > it_const_symbols
Iterator that outputs const Symbol&.
Definition MachO/Binary.hpp:129
RPathCommand * rpath()
Return the MachO::RPathCommand command if present, a nullptr otherwise.
SegmentCommand * get_segment(const std::string &name)
Return the segment from the given name.
Definition MachO/Binary.hpp:538
span< const uint8_t > get_content_from_virtual_address(uint64_t virtual_address, uint64_t size, Binary::VA_TYPES addr_type=Binary::VA_TYPES::AUTO) const override
Return the content located at virtual address.
const CodeSignatureDir * code_signature_dir() const
bool extend_segment(const SegmentCommand &segment, size_t size)
Extend the content of the given SegmentCommand.
ref_iterator< libraries_cache_t & > it_libraries
Iterator that outputs DylibCommand&.
Definition MachO/Binary.hpp:167
const T * command() const
const_filter_iterator< const commands_t &, const SubClient * > it_const_sub_clients
Iterator which outputs const SubClient&.
Definition MachO/Binary.hpp:219
SymbolCommand * symbol_command()
Return the MachO::SymbolCommand if present, a nullptr otherwise.
LinkerOptHint * linker_opt_hint()
Return the MachO::LinkerOptHint if present, a nullptr otherwise.
Definition MachO/Binary.hpp:964
uint64_t fat_offset() const
Return binary's fat offset. 0 if not relevant.
Definition MachO/Binary.hpp:611
const Header & header() const
Definition MachO/Binary.hpp:243
ref_iterator< lazy_load_dylib_info_cache_t & > it_lazy_load_dylib_info
Iterator that outputs LazyLoadDylibInfo&.
Definition MachO/Binary.hpp:176
it_rpaths rpaths()
Iterator over all the MachO::RPathCommand commands.
bool has_nx_heap() const
Return True if the heap is flagged as non-executable. False otherwise.
Definition MachO/Binary.hpp:697
const AtomInfo * atom_info() const
LoadCommand * add(const LoadCommand &command)
Insert a new LoadCommand.
Definition MachO/Binary.hpp:402
bool remove(const Symbol &sym)
Remove the given symbol.
bool has_version_min() const
true if the binary has a MachO::VersionMin command.
Definition MachO/Binary.hpp:763
DyldEnvironment * dyld_environment()
Return the MachO::DyldEnvironment if present, a nullptr otherwise.
bool has_notes() const
True if the binary contains LC_NOTE command(s).
Definition MachO/Binary.hpp:1008
bool remove(const LoadCommand &command)
Remove the given LoadCommand.
SourceVersion * source_version()
Return the MachO::SourceVersion command if present, a nullptr otherwise.
static bool is_imported(const Symbol &symbol)
Check if the given symbol is an imported one.
LoadCommand * add(const LoadCommand &command, size_t index)
Insert a new LoadCommand at the specified index.
std::vector< std::unique_ptr< Symbol > > symbols_t
Internal container for storing Mach-O Symbol.
Definition MachO/Binary.hpp:123
void patch_address(uint64_t address, uint64_t patch_value, size_t size=sizeof(uint64_t), LIEF::Binary::VA_TYPES addr_type=LIEF::Binary::VA_TYPES::AUTO) override
Patch the address with the given value.
CodeSignature * code_signature()
Return the MachO::CodeSignature if present, a nullptr otherwise.
Definition MachO/Binary.hpp:826
LoadCommand * add_library(const std::string &name)
Insert a new shared library through a LC_LOAD_DYLIB command.
Section * add_section(const SegmentCommand &segment, const Section §ion)
Add a section in the given MachO::SegmentCommand.
void remove_section(const std::string &name, bool clear=false) override
Remove the section with the name provided in the first parameter.
const Symbol * get_symbol(const std::string &name) const
Return Symbol from the given name. If the symbol does not exist, it returns a null pointer.
bool remove_command(size_t index)
Remove the Load Command at the provided index.
ref_iterator< symbols_t &, Symbol * > it_symbols
Iterator that outputs Symbol&.
Definition MachO/Binary.hpp:126
uint64_t memory_base_address() const
If this Mach-O binary has been parsed from memory, it returns the in-memory base address of this bina...
Definition MachO/Binary.hpp:1103
bool has_sub_framework() const
true if the binary has a sub framework command.
Definition MachO/Binary.hpp:865
LIEF::Binary::functions_t functions() const
Return all the functions found in this MachO.
const LoadCommand * get(LoadCommand::TYPE type) const
Return the LoadCommand associated with the given LoadCommand::TYPE or a nullptr if the command can't ...
const LinkerOptHint * linker_opt_hint() const
ref_iterator< sections_cache_t & > it_sections
Iterator that outputs Section&.
Definition MachO/Binary.hpp:149
FunctionStarts * function_starts()
Return the MachO::FunctionStarts command if present, a nullptr otherwise.
friend class Parser
Definition MachO/Binary.hpp:93
SegmentSplitInfo * segment_split_info()
Return the MachO::SegmentSplitInfo if present, a nullptr otherwise.
ref_iterator< segments_cache_t & > it_segments
Iterator that outputs SegmentCommand&.
Definition MachO/Binary.hpp:158
stub_iterator symbol_stubs() const
Return an iterator over the symbol stubs.
LoadCommand * add(const SegmentCommand &segment)
Add a new LC_SEGMENT command from the given SegmentCommand.
bool is_ios() const
True if this binary targets iOS.
Definition MachO/Binary.hpp:915
bool has_entrypoint() const
true if the binary has an entrypoint.
Definition MachO/Binary.hpp:704
ref_iterator< fileset_binaries_t &, Binary * > it_fileset_binaries
Iterator that outputs Binary&.
Definition MachO/Binary.hpp:186
bool has_two_level_hints() const
true if the binary has the command LC_TWO_LEVEL_HINTS.
Definition MachO/Binary.hpp:946
DyldInfo * dyld_info()
Return the MachO::Dyld command if present, a nullptr otherwise.
void patch_address(uint64_t address, const std::vector< uint8_t > &patch_value, LIEF::Binary::VA_TYPES addr_type=LIEF::Binary::VA_TYPES::AUTO) override
Patch the content at virtual address address with patch_value.
MainCommand * main_command()
Return the MachO::MainCommand if present, a nullptr otherwise.
const_filter_iterator< const symbols_t &, const Symbol * > it_const_imported_symbols
Iterator that outputs imported const Symbol&.
Definition MachO/Binary.hpp:142
bool has_encryption_info() const
true if the binary has Encryption Info.
Definition MachO/Binary.hpp:870
bool has(LoadCommand::TYPE type) const
Check if the current binary has the given MachO::LoadCommand::TYPE.
DylibCommand * find_library(const std::string &name)
Definition MachO/Binary.hpp:428
range_t va_ranges() const
Return the range of virtual addresses.
DynamicSymbolCommand * dynamic_symbol_command()
Return the MachO::SymbolCommand if present, a nullptr otherwise.
bool has_code_signature_dir() const
true if the binary is signed with the command DYLIB_CODE_SIGN_DRS
Definition MachO/Binary.hpp:834
CodeSignatureDir * code_signature_dir()
Return the MachO::CodeSignatureDir if present, a nullptr otherwise.
Definition MachO/Binary.hpp:839
const_ref_iterator< const segments_cache_t & > it_const_segments
Iterator that outputs const SegmentCommand&.
Definition MachO/Binary.hpp:161
std::set< Relocation *, KeyCmp > relocations_t
Internal container that store all the relocations found in a Mach-O. The relocations are actually own...
Definition MachO/Binary.hpp:199
bool has_code_signature() const
true if the binary is signed with LC_CODE_SIGNATURE command
Definition MachO/Binary.hpp:821
AtomInfo * atom_info()
Return the MachO::AtomInfo if present, a nullptr otherwise.
Definition MachO/Binary.hpp:997
ref_iterator< commands_t &, LoadCommand * > it_commands
Iterator that outputs LoadCommand&.
Definition MachO/Binary.hpp:117
std::vector< Section * > sections_cache_t
Internal container for caching Mach-O Section.
Definition MachO/Binary.hpp:146
const Section * get_section(const std::string &segname, const std::string &secname) const
bool has_section(const std::string &name) const
Check if a section with the given name exists.
Definition MachO/Binary.hpp:499
it_const_imported_symbols imported_symbols() const
Definition MachO/Binary.hpp:312
bool has_main_command() const
true if the binary has a MachO::MainCommand command.
Definition MachO/Binary.hpp:718
Header & header()
Return a reference to the MachO::Header.
Definition MachO/Binary.hpp:239
ExportInfo * add_exported_function(uint64_t address, const std::string &name)
Add a symbol in the export trie of the current binary.
bool support_arm64_ptr_auth() const
Check if the binary is supporting ARM64 pointer authentication (arm64e).
Definition MachO/Binary.hpp:1108
it_const_commands commands() const
Definition MachO/Binary.hpp:253
bool has_dyld_environment() const
true if the binary has Dyld environment variables.
Definition MachO/Binary.hpp:889
it_const_libraries libraries() const
Definition MachO/Binary.hpp:323
const_ref_iterator< const lazy_load_dylib_info_cache_t & > it_const_lazy_load_dylib_info
Iterator that outputs const LazyLoadDylibInfo&.
Definition MachO/Binary.hpp:179
bool has_function_variants() const
true if the binary has the command LC_FUNCTION_VARIANTS.
Definition MachO/Binary.hpp:1013
const_filter_iterator< const symbols_t &, const Symbol * > it_const_exported_symbols
Iterator that outputs exported const Symbol&.
Definition MachO/Binary.hpp:135
const std::string & fileset_name() const
Name associated with the LC_FILESET_ENTRY for this MachO. For instance: com.apple....
Definition MachO/Binary.hpp:1078
Binary & for_commands(Func f)
FunctionVariantFixups * function_variant_fixups()
Return the FunctionVariantFixups if present, a nullptr otherwise.
Definition MachO/Binary.hpp:1032
iterator_range< Stub::Iterator > stub_iterator
Iterator type for Symbol's stub.
Definition MachO/Binary.hpp:225
bool has_filesets() const
true if the binary has a LoadCommand::TYPE::FILESET_ENTRY command
Definition MachO/Binary.hpp:1072
Symbol * get_symbol(const std::string &name)
Definition MachO/Binary.hpp:283
SegmentCommand * segment_from_offset(uint64_t offset)
Return the binary's SegmentCommand that encompasses the provided offset.
Definition MachO/Binary.hpp:599
friend class DyldInfo
Definition MachO/Binary.hpp:96
const_ref_iterator< const fileset_binaries_t &, Binary * > it_const_fileset_binaries
Iterator that outputs const Binary&.
Definition MachO/Binary.hpp:189
LoadCommand * add(std::unique_ptr< LoadCommand > command)
bool unexport(const std::string &name)
Remove the given MachO::Symbol with the given name from the export table.
LIEF::Binary::functions_t unwind_functions() const
Return the functions found in the __unwind_info section.
it_const_exported_symbols exported_symbols() const
Definition MachO/Binary.hpp:296
bool has_thread_command() const
true if the binary has a MachO::ThreadCommand command.
Definition MachO/Binary.hpp:772
Symbol & add(const Symbol &symbol)
Add a symbol to this binary.
bool unexport(const Symbol &sym)
Remove the given symbol from the export table.
SubFramework * sub_framework()
Return the MachO::SubFramework if present, a nullptr otherwise.
uint64_t virtual_size() const override
Size of the binary in memory when mapped by the loader (dyld).
Definition MachO/Binary.hpp:490
Routine * routine_command()
Return the MachO::Routine command if present, a nullptr otherwise.
const_ref_iterator< const libraries_cache_t & > it_const_libraries
Iterator that outputs const DylibCommand&.
Definition MachO/Binary.hpp:170
it_sections sections()
Return an iterator over the MachO::Section.
Definition MachO/Binary.hpp:346
Definition BuildVersion.hpp:34
@ MACOS
Definition BuildVersion.hpp:46
@ UNKNOWN
Definition BuildVersion.hpp:45
@ IOS
Definition BuildVersion.hpp:47
Definition CodeSignatureDir.hpp:37
Definition CodeSignature.hpp:38
Interface of the LC_DATA_IN_CODE command This command is used to list slices of code sections that co...
Definition DataInCode.hpp:43
Class that represents the LC_DYLD_CHAINED_FIXUPS command.
Definition DyldChainedFixups.hpp:50
Class that represents a LC_DYLD_ENVIRONMENT command which is used by the Mach-O linker/loader to init...
Definition DyldEnvironment.hpp:34
Class that represents the LC_DYLD_EXPORTS_TRIE command.
Definition DyldExportsTrie.hpp:43
Class which represents a library dependency.
Definition DylibCommand.hpp:34
Class that represents the Mach-O linker, also named loader. Most of the time, DylinkerCommand::name()...
Definition DylinkerCommand.hpp:34
Class that represents the LC_DYSYMTAB command.
Definition DynamicSymbolCommand.hpp:40
Class that represents the LC_ENCRYPTION_INFO / LC_ENCRYPTION_INFO_64 commands.
Definition EncryptionInfo.hpp:35
Class that provides an interface over the Dyld export info.
Definition ExportInfo.hpp:38
Class which represents the LC_FUNCTION_STARTS command.
Definition FunctionStarts.hpp:40
Class which represents the LC_FUNCTION_VARIANT_FIXUPS command.
Definition FunctionVariantFixups.hpp:60
Class representing the LC_FUNCTION_VARIANTS load command.
Definition FunctionVariants.hpp:69
Class which represents the LC_LINKER_OPTIMIZATION_HINT command.
Definition LinkerOptHint.hpp:38
Base class for the Mach-O load commands.
Definition LoadCommand.hpp:38
TYPE
Definition LoadCommand.hpp:46
@ NOTE
Definition LoadCommand.hpp:97
@ VERSION_MIN_MACOSX
Definition LoadCommand.hpp:84
@ VERSION_MIN_IPHONEOS
Definition LoadCommand.hpp:85
Class that represents the LC_MAIN command. This kind of command can be used to determine the entrypoi...
Definition MainCommand.hpp:33
Class that represents the LC_RPATH command.
Definition RPathCommand.hpp:36
Class that represents a Mach-O relocation.
Definition MachO/Relocation.hpp:40
Class that represents the LC_ROUTINE/LC_ROUTINE64 commands. According to the Mach-O loader....
Definition Routine.hpp:38
Class that represents a Mach-O section.
Definition MachO/Section.hpp:48
Class which represents a LoadCommand::TYPE::SEGMENT / LoadCommand::TYPE::SEGMENT_64 command.
Definition SegmentCommand.hpp:52
Class that represents the LoadCommand::TYPE::SEGMENT_SPLIT_INFO command.
Definition SegmentSplitInfo.hpp:36
Class that represents the MachO LoadCommand::TYPE::SOURCE_VERSION This command is used to provide the...
Definition SourceVersion.hpp:35
Class that represents the SubFramework command. According to the Mach-O loader.h documentation:
Definition SubFramework.hpp:46
Class that represents the LC_SYMTAB command.
Definition SymbolCommand.hpp:36
Class that represents a Symbol in a Mach-O file.
Definition MachO/Symbol.hpp:47
Class that represents the LC_THREAD / LC_UNIXTHREAD commands and that can be used to get the binary e...
Definition ThreadCommand.hpp:43
Class which represents the LC_TWOLEVEL_HINTS command.
Definition TwoLevelHints.hpp:40
Class that represents the UUID command.
Definition UUIDCommand.hpp:35
Class that wraps the LC_VERSION_MIN_MACOSX, LC_VERSION_MIN_IPHONEOS, ... commands.
Definition VersionMin.hpp:34
Main interface to parse an executable regardless of its format.
Definition Abstract/Parser.hpp:30
Class which represents an abstracted Relocation.
Definition Abstract/Relocation.hpp:27
Class which represents an abstracted section.
Definition Abstract/Section.hpp:30
This class represents a symbol in an executable format.
Definition Abstract/Symbol.hpp:28
Definition Visitor.hpp:212
Iterator which returns a ref on container's values given predicates.
Definition iterators.hpp:327
Definition iterators.hpp:601
Opaque structure that is used by LIEF to avoid writing result<void> f(...). Instead,...
Definition errors.hpp:118
Iterator which returns reference on container's values.
Definition iterators.hpp:47
Wrapper that contains an Object (T) or an error.
Definition errors.hpp:78
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
Namespace related to the LIEF's Mach-O module.
Definition Abstract/Header.hpp:36
Namespace related to ObjC metadata.
Definition MachO/Binary.hpp:43
LIEF namespace.
Definition Abstract/Binary.hpp:41
uint64_t align(uint64_t value, uint64_t align_on)
Definition utils.hpp:28
filter_iterator< CT, U, typename decay_t< CT >::const_iterator > const_filter_iterator
Iterator which returns a const ref on container's values given predicates.
Definition iterators.hpp:593
ok_t ok()
Return success for function with return type ok_error_t.
Definition errors.hpp:102
tcb::span< ElementType, Extent > span
Definition span.hpp:22
lief_version_t version()
Return the current version.
ref_iterator< CT, U, typename decay_t< CT >::const_iterator > const_ref_iterator
Iterator which returns a const ref on container's values.
Definition iterators.hpp:320
PLATFORMS
Definition platforms.hpp:26
Definition MachO/Binary.hpp:192
bool operator()(const Relocation *lhs, const Relocation *rhs) const
Definition MachO/Binary.hpp:100
uint64_t start
Definition MachO/Binary.hpp:101
uint64_t size() const
Definition MachO/Binary.hpp:104
uint64_t end
Definition MachO/Binary.hpp:102
bool empty() const
Definition MachO/Binary.hpp:108
#define LIEF_API
Definition visibility.h:45
#define LIEF_LOCAL
Definition visibility.h:46