LIEF: Library to Instrument Executable Formats Version 1.0.0
Loading...
Searching...
No Matches
FatBinary.hpp
Go to the documentation of this file.
1/* Copyright 2017 - 2026 R. Thomas
2 * Copyright 2017 - 2026 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_MACHO_FAT_BINARY_H
17#define LIEF_MACHO_FAT_BINARY_H
18#include <string>
19#include <vector>
20#include <memory>
21
22#include "LIEF/visibility.h"
23#include "LIEF/iterators.hpp"
24#include "LIEF/MachO/Header.hpp"
25
26namespace LIEF {
27class Parser;
28namespace MachO {
29
30class Parser;
31class Builder;
32class Binary;
33
37
38 friend class LIEF::Parser;
39 friend class Parser;
40 friend class Builder;
41
42 public:
43
45 using binaries_t = std::vector<std::unique_ptr<Binary>>;
46
49
52
53 FatBinary(const FatBinary&) = delete;
54 FatBinary& operator=(const FatBinary&) = delete;
55
56 virtual ~FatBinary();
57
59 size_t size() const {
60 return binaries_.size();
61 }
62
64 bool empty() const {
65 return binaries_.empty();
66 }
67
69 return binaries_;
70 }
72 return binaries_;
73 }
74
76 return it_binaries(binaries_).end();
77 }
78
80 return it_const_binaries(binaries_).end();
81 }
82
84 for (auto& bin : binaries_) {
85 bin.release(); // NOLINT(bugprone-unused-return-value)
86 }
87 }
88
91 std::unique_ptr<Binary> pop_back();
92
95 Binary* at(size_t index) {
96 return const_cast<Binary*>(static_cast<const FatBinary*>(this)->at(index));
97 }
98
99 const Binary* at(size_t index) const {
100 if (index >= size()) {
101 return nullptr;
102 }
103 return binaries_[index].get();
104 }
105
107 return const_cast<Binary*>(static_cast<const FatBinary*>(this)->back());
108 }
109 const Binary* back() const {
110 return binaries_.empty() ? nullptr : binaries_.back().get();
111 }
112
114 return const_cast<Binary*>(static_cast<const FatBinary*>(this)->front());
115 }
116
117 const Binary* front() const {
118 return binaries_.empty() ? nullptr : binaries_.front().get();
119 }
120
121 Binary* operator[](size_t index) {
122 return at(index);
123 }
124 const Binary* operator[](size_t index) const {
125 return at(index);
126 }
127
132 std::unique_ptr<Binary> take(size_t index);
133
136 std::unique_ptr<Binary> take(Header::CPU_TYPE cpu);
137
140 void write(const std::string& filename);
141
143 std::vector<uint8_t> raw();
144
145 LIEF_API friend std::ostream& operator<<(std::ostream& os, const FatBinary& fatbinary);
146
147 private:
150 binaries_t binaries_;
151};
152
153} // namespace MachO
154} // namespace LIEF
155#endif
Class which represents a MachO binary.
Definition MachO/Binary.hpp:88
const LoadCommand * get(LoadCommand::TYPE type) const
Return the LoadCommand associated with the given LoadCommand::TYPE or a nullptr if the command can't ...
Class used to rebuild a Mach-O file.
Definition MachO/Builder.hpp:63
it_binaries end()
Definition FatBinary.hpp:75
Binary * front()
Definition FatBinary.hpp:113
std::unique_ptr< Binary > pop_back()
Get a pointer to the last MachO::Binary object presents in this Fat Binary. It returns a nullptr if n...
bool empty() const
Checks whether this object contains MachO::Binary.
Definition FatBinary.hpp:64
std::unique_ptr< Binary > take(Header::CPU_TYPE cpu)
Take the underlying MachO::Binary that matches the given architecture If no binary with the architect...
std::vector< uint8_t > raw()
Reconstruct the Fat binary object and return his content as bytes.
FatBinary(const FatBinary &)=delete
friend std::ostream & operator<<(std::ostream &os, const FatBinary &fatbinary)
ref_iterator< binaries_t &, Binary * > it_binaries
Iterator that outputs Binary&.
Definition FatBinary.hpp:48
std::unique_ptr< Binary > take(size_t index)
Extract a MachO::Binary object. Gives ownership to the caller, and remove it from this FatBinary obje...
const Binary * at(size_t index) const
Definition FatBinary.hpp:99
const Binary * back() const
Definition FatBinary.hpp:109
Binary * operator[](size_t index)
Definition FatBinary.hpp:121
it_binaries begin()
Definition FatBinary.hpp:68
friend class Builder
Definition FatBinary.hpp:40
it_const_binaries begin() const
Definition FatBinary.hpp:71
std::vector< std::unique_ptr< Binary > > binaries_t
Internal container used to store Binary objects within a Fat Mach-O.
Definition FatBinary.hpp:45
Binary * back()
Definition FatBinary.hpp:106
const Binary * front() const
Definition FatBinary.hpp:117
void write(const std::string &filename)
Reconstruct the Fat binary object and write it in filename.
FatBinary & operator=(const FatBinary &)=delete
friend class LIEF::Parser
Definition FatBinary.hpp:38
it_const_binaries end() const
Definition FatBinary.hpp:79
const_ref_iterator< const binaries_t &, Binary * > it_const_binaries
Iterator that outputs const Binary&.
Definition FatBinary.hpp:51
Binary * at(size_t index)
Get a pointer to the MachO::Binary specified by the index. It returns a nullptr if the binary does no...
Definition FatBinary.hpp:95
size_t size() const
Number of MachO::Binary wrapped by this object.
Definition FatBinary.hpp:59
const Binary * operator[](size_t index) const
Definition FatBinary.hpp:124
void release_all_binaries()
Definition FatBinary.hpp:83
CPU_TYPE
Definition MachO/Header.hpp:101
The main interface to parse a Mach-O binary.
Definition MachO/Parser.hpp:42
Main interface to parse an executable regardless of its format.
Definition Abstract/Parser.hpp:30
Iterator which returns reference on container's values.
Definition iterators.hpp:46
Namespace related to the LIEF's Mach-O module.
Definition Abstract/Header.hpp:36
LIEF namespace.
Definition Abstract/Binary.hpp:40
ref_iterator< CT, U, typename decay_t< CT >::const_iterator > const_ref_iterator
Iterator which return const ref on container's values.
Definition iterators.hpp:257
#define LIEF_API
Definition visibility.h:41
#define LIEF_LOCAL
Definition visibility.h:42