LIEF: Library to Instrument Executable Formats Version 0.17.0
Loading...
Searching...
No Matches
Dylib.hpp
Go to the documentation of this file.
1/* Copyright 2017 - 2025 R. Thomas
2 * Copyright 2017 - 2025 Quarkslab
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#ifndef LIEF_DSC_DYLIB_H
17#define LIEF_DSC_DYLIB_H
18#include "LIEF/visibility.h"
19#include "LIEF/iterators.hpp"
20#include "LIEF/errors.hpp"
21
22#include <memory>
23#include <string>
24
25namespace LIEF {
26
27namespace MachO {
28class Binary;
29}
30
31namespace dsc {
32
33namespace details {
34class Dylib;
35class DylibIt;
36}
37
41 public:
44 public iterator_facade_base<Iterator, std::random_access_iterator_tag,
45 std::unique_ptr<Dylib>, std::ptrdiff_t, Dylib*,
46 std::unique_ptr<Dylib>>
47 {
48 public:
49 using implementation = details::DylibIt;
50
51 Iterator(std::unique_ptr<details::DylibIt> impl);
54
55 Iterator(Iterator&&) noexcept;
56 Iterator& operator=(Iterator&&) noexcept;
57
59 bool operator<(const Iterator& rhs) const;
60
61 std::ptrdiff_t operator-(const Iterator& R) const;
62
63 Iterator& operator+=(std::ptrdiff_t n);
64 Iterator& operator-=(std::ptrdiff_t n);
65
66 friend LIEF_API bool operator==(const Iterator& LHS, const Iterator& RHS);
67
68 friend LIEF_API bool operator!=(const Iterator& LHS, const Iterator& RHS) {
69 return !(LHS == RHS);
70 }
71
72 std::unique_ptr<Dylib> operator*() const;
73
74 private:
75 std::unique_ptr<details::DylibIt> impl_;
76 };
77 public:
83
88 bool pack = true;
89
96 bool fix_branches = false;
97
103 bool fix_memory = false;
104
110 bool fix_relocations = false;
111
113 bool fix_objc = false;
114
120 };
121
122 Dylib(std::unique_ptr<details::Dylib> impl);
124
126 std::string path() const;
127
129 uint64_t address() const;
130
132 uint64_t modtime() const;
133
138 uint64_t inode() const;
139
141 uint64_t padding() const;
142
150 std::unique_ptr<LIEF::MachO::Binary> get(const extract_opt_t& opt = extract_opt_t()) const;
151
152 private:
153 std::unique_ptr<details::Dylib> impl_;
154};
155
156}
157}
158#endif
Class which represents a MachO binary.
Definition MachO/Binary.hpp:88
Iterator & operator=(const Iterator &)
std::unique_ptr< Dylib > operator*() const
Iterator(const Iterator &)
details::DylibIt implementation
Definition Dylib.hpp:49
Iterator(std::unique_ptr< details::DylibIt > impl)
Iterator(Iterator &&) noexcept
std::string path() const
Original path of the library (e.g. /usr/lib/libcryptex.dylib).
uint64_t modtime() const
Modification time of the library matching stat.st_mtime, or 0.
uint64_t padding() const
Padding alignment value (should be 0).
std::unique_ptr< LIEF::MachO::Binary > get(const extract_opt_t &opt=extract_opt_t()) const
Get a MachO::Binary representation for this Dylib.
uint64_t inode() const
File serial number matching stat.st_ino or 0.
uint64_t address() const
In-memory address of the library.
Dylib(std::unique_ptr< details::Dylib > impl)
CRTP base class which implements the entire standard iterator facade in terms of a minimal subset of ...
Definition iterators.hpp:590
Namespace related to the LIEF's Mach-O module.
Definition Abstract/Header.hpp:36
Definition DyldSharedCache/DyldSharedCache.hpp:35
Namespace related to the dyld shared cache support.
Definition caching.hpp:22
LIEF namespace.
Definition Abstract/Binary.hpp:40
tl::expected< T, lief_errors > result
Wrapper that contains an Object (T) or an error.
Definition errors.hpp:75
This structure is used to tweak the extraction process while calling Dylib::get. These options allow ...
Definition Dylib.hpp:81
LIEF::result< bool > create_dyld_chained_fixup_cmd
Whether the LC_DYLD_CHAINED_FIXUPS command should be (re)created.
Definition Dylib.hpp:119
bool fix_relocations
Recover and fix relocations.
Definition Dylib.hpp:110
bool fix_branches
Fix call instructions that target addresses outside the current dylib virtual space.
Definition Dylib.hpp:96
bool fix_memory
Fix memory accesses performed outside the dylib's virtual space.
Definition Dylib.hpp:103
bool pack
Whether the segment's offsets should be packed to avoid an in-memory size while writing back the bina...
Definition Dylib.hpp:88
bool fix_objc
Fix Objective-C information.
Definition Dylib.hpp:113
#define LIEF_API
Definition visibility.h:41