LIEF: Library to Instrument Executable Formats Version 0.17.0
Loading...
Searching...
No Matches
iostream.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_OSTREAM_H
17#define LIEF_OSTREAM_H
18#include <limits>
19#include <ios>
20#include <cstdint>
21#include <cstring>
22#include <vector>
23#include <array>
24
25#include "LIEF/span.hpp"
27
28namespace LIEF {
30 public:
31 static size_t uleb128_size(uint64_t value);
32 static size_t sleb128_size(int64_t value);
33 using pos_type = std::streampos;
34 using off_type = std::streamoff;
35 vector_iostream() = default;
36 vector_iostream(bool endian_swap) :
37 endian_swap_(endian_swap)
38 {}
39 void reserve(size_t size) {
40 raw_.reserve(size);
41 }
42
43 vector_iostream& put(uint8_t c);
44 vector_iostream& write(const uint8_t* s, std::streamsize n);
46 return write(sp.data(), sp.size());
47 }
48
49 vector_iostream& write(std::vector<uint8_t> s) {
50 if (s.empty()) {
51 return *this;
52 }
53 return write(s.data(), s.size());
54 }
55
56 vector_iostream& write(const std::string& s) {
57 return write(reinterpret_cast<const uint8_t*>(s.c_str()), s.size() + 1);
58 }
59
60 vector_iostream& write(const std::u16string& s, bool with_null_char);
61
62 vector_iostream& write(size_t count, uint8_t value) {
63 raw_.insert(std::end(raw_), count, value);
64 current_pos_ += count;
65 return *this;
66 }
67 vector_iostream& write_sized_int(uint64_t value, size_t size) {
68 const uint64_t stack_val = value;
69 return write(reinterpret_cast<const uint8_t*>(&stack_val), size);
70 }
72 return write(other.raw());
73 }
74
75 template<class T, typename = typename std::enable_if<std::is_standard_layout<T>::value && std::is_trivial<T>::value>::type>
76 vector_iostream& write(const T& t) {
77 const auto pos = static_cast<size_t>(tellp());
78 if (raw_.size() < (pos + sizeof(T))) {
79 raw_.resize(pos + sizeof(T));
80 }
81 if (endian_swap_) {
82 T tmp = t;
83 swap_endian(&tmp);
84 memcpy(raw_.data() + pos, &tmp, sizeof(T));
85 } else {
86 memcpy(raw_.data() + pos, &t, sizeof(T));
87 }
88 current_pos_ += sizeof(T);
89 return *this;
90 }
91
92 vector_iostream& align(size_t alignment, uint8_t fill = 0);
93
94 template<typename T, size_t size>
95 vector_iostream& write(const std::array<T, size>& t) {
96 static_assert(std::numeric_limits<T>::is_integer, "Requires integer type");
97 for (T val : t) {
98 write<T>(val);
99 }
100 return *this;
101 }
102
103 template<typename T>
104 vector_iostream& write(const std::vector<T>& elements) {
105 for (const T& e : elements) {
106 write(e);
107 }
108 return *this;
109 }
110
113
114 vector_iostream& get(std::vector<uint8_t>& c) {
115 c = raw_;
116 return *this;
117 }
118 vector_iostream& move(std::vector<uint8_t>& c) {
119 c = std::move(raw_);
120 return *this;
121 }
122
124 return *this;
125 }
126
127 size_t size() const {
128 return raw_.size();
129 }
130
131 // seeks:
132 pos_type tellp() const {
133 return current_pos_;
134 }
135
137 current_pos_ = p;
138 return *this;
139 }
140
141 vector_iostream& seekp(vector_iostream::off_type p, std::ios_base::seekdir dir);
142
143 const std::vector<uint8_t>& raw() const {
144 return raw_;
145 }
146
147 std::vector<uint8_t>& raw() {
148 return raw_;
149 }
150
151 void set_endian_swap(bool swap) {
152 endian_swap_ = swap;
153 }
154
155 private:
156 pos_type current_pos_ = 0;
157 std::vector<uint8_t> raw_;
158 bool endian_swap_ = false;
159};
160
161
162}
163#endif
Definition iostream.hpp:29
std::vector< uint8_t > & raw()
Definition iostream.hpp:147
static size_t sleb128_size(int64_t value)
vector_iostream & flush()
Definition iostream.hpp:123
vector_iostream & seekp(vector_iostream::off_type p, std::ios_base::seekdir dir)
const std::vector< uint8_t > & raw() const
Definition iostream.hpp:143
vector_iostream & write(const std::array< T, size > &t)
Definition iostream.hpp:95
size_t size() const
Definition iostream.hpp:127
vector_iostream & put(uint8_t c)
vector_iostream & write_uleb128(uint64_t value)
vector_iostream & write(const uint8_t *s, std::streamsize n)
vector_iostream & seekp(pos_type p)
Definition iostream.hpp:136
vector_iostream & write(const std::u16string &s, bool with_null_char)
void reserve(size_t size)
Definition iostream.hpp:39
vector_iostream & move(std::vector< uint8_t > &c)
Definition iostream.hpp:118
vector_iostream & write_sized_int(uint64_t value, size_t size)
Definition iostream.hpp:67
vector_iostream & write(const std::string &s)
Definition iostream.hpp:56
std::streampos pos_type
Definition iostream.hpp:33
pos_type tellp() const
Definition iostream.hpp:132
vector_iostream & write(const vector_iostream &other)
Definition iostream.hpp:71
vector_iostream & write(span< const uint8_t > sp)
Definition iostream.hpp:45
vector_iostream & align(size_t alignment, uint8_t fill=0)
void set_endian_swap(bool swap)
Definition iostream.hpp:151
vector_iostream & write(std::vector< uint8_t > s)
Definition iostream.hpp:49
vector_iostream & write(const T &t)
Definition iostream.hpp:76
static size_t uleb128_size(uint64_t value)
std::streamoff off_type
Definition iostream.hpp:34
vector_iostream & write(const std::vector< T > &elements)
Definition iostream.hpp:104
vector_iostream & write_sleb128(int64_t value)
vector_iostream & write(size_t count, uint8_t value)
Definition iostream.hpp:62
vector_iostream(bool endian_swap)
Definition iostream.hpp:36
vector_iostream & get(std::vector< uint8_t > &c)
Definition iostream.hpp:114
LIEF namespace.
Definition Abstract/Binary.hpp:36
tcb::span< ElementType, Extent > span
Definition span.hpp:22
void swap_endian(T *)
Definition endianness_support.hpp:116