16#ifndef LIEF_BINARY_STREAM_H
17#define LIEF_BINARY_STREAM_H
51 virtual uint64_t
size()
const = 0;
70 size_t maxsize = ~
static_cast<size_t>(0))
const;
83 uint64_t
size, uint64_t virtual_address = 0) {
89 const bool read_ok = offset <= this->size() &&
90 (offset +
size) <= this->size()
92 && (
static_cast<int64_t
>(offset) >= 0 &&
93 static_cast<int64_t
>(
size) >= 0) &&
94 (
static_cast<int64_t
>(offset +
size) >= 0);
99 if (container.size() <
size) {
100 std::vector<uint8_t> buffer(
size);
102 container = std::move(buffer);
106 return peek_in(container.data(), offset,
size, virtual_address);
119 const size_t size = this->size() - this->
pos();
128 const size_t size = count *
sizeof(T);
148 const auto current_p =
pos();
151 const size_t size = count *
sizeof(T);
160 if (container.size() < count) {
161 std::vector<T> buffer(count);
163 container = std::move(buffer);
194 return pos_ <
size();
197 operator bool()
const {
202 const T* read_array(
size_t size)
const;
204 template<
class T,
size_t N>
215 && (
static_cast<int64_t
>(pos_) >= 0 &&
static_cast<int64_t
>(N) >= 0) &&
216 (
static_cast<int64_t
>(pos_ + N) >= 0);
221 if (
peek_in(dst.data(), pos_, N)) {
227 template<
class T,
size_t N>
244 const T* peek_array(
size_t size)
const;
247 const T* peek_array(
size_t offset,
size_t size)
const;
253 bool can_read()
const;
256 bool can_read(
size_t offset)
const;
259 return offset < (int64_t)this->size() &&
260 (offset +
size) < (int64_t)this->size();
263 size_t align(
size_t align_on)
const;
271 const auto* ptr =
reinterpret_cast<const uint8_t* const
>(&buffer);
272 return std::all_of(ptr, ptr +
sizeof(T), [](uint8_t x) {
return x == 0; });
279 virtual const uint8_t*
p()
const {
284 return const_cast<uint8_t*
>(
static_cast<const BinaryStream*
>(
this)->start());
287 virtual uint8_t*
p() {
288 return const_cast<uint8_t*
>(
static_cast<const BinaryStream*
>(
this)->p());
292 return const_cast<uint8_t*
>(
static_cast<const BinaryStream*
>(
this)->end());
295 virtual const uint8_t*
start()
const {
299 virtual const uint8_t*
end()
const {
304 uint64_t virtual_address = 0)
const = 0;
306 uint64_t virtual_address = 0)
const {
307 if (
auto raw =
read_at(offset,
size, virtual_address)) {
308 if (dst ==
nullptr) {
312 const void* ptr = *raw;
314 if (ptr ==
nullptr) {
318 memcpy(dst, ptr,
size);
326 static_assert(std::is_base_of<BinaryStream, T>::value,
327 "Require BinaryStream inheritance");
328 if (T::classof(*
this)) {
329 return static_cast<const T*
>(
this);
336 return const_cast<T*
>(
static_cast<const BinaryStream*
>(
this)->cast<T>());
342 mutable size_t pos_ = 0;
343 bool endian_swap_ =
false;
344 STREAM_TYPE stype_ = STREAM_TYPE::UNKNOWN;
366 stream_.setpos(pos_);
395 endian_swap_(stream.should_swap()),
401 endian_swap_(stream.should_swap()),
407 stream_.set_endian_swap(endian_swap_);
423 bool endian_swap_ =
false;
440 const auto current_p =
pos();
442 if (
auto res =
peek_in(&ret,
pos(),
sizeof(T))) {
456 const size_t saved_offset = this->
pos();
459 this->
setpos(saved_offset);
470 return reinterpret_cast<const T*
>(raw.value());
475 const size_t saved_offset = this->
pos();
478 this->
setpos(saved_offset);
487 return pos_ <
size() && (pos_ +
sizeof(T)) <
size();
495 return offset <
size() && (offset +
sizeof(T)) <
size();
Definition ASN1Reader.hpp:32
Class that is used to a read stream of data from different sources.
Definition BinaryStream.hpp:34
size_t align(size_t align_on) const
ok_error_t peek_array(std::array< T, N > &dst) const
Definition BinaryStream.hpp:205
result< std::string > read_mutf8(size_t maxsize=~static_cast< size_t >(0)) const
STREAM_TYPE
Definition BinaryStream.hpp:38
@ MEMORY
Definition BinaryStream.hpp:41
result< T > peek() const
Definition BinaryStream.hpp:439
result< int64_t > read_dwarf_encoded(uint8_t encoding) const
virtual uint8_t * p()
Definition BinaryStream.hpp:287
result< std::string > peek_string(size_t maxsize=~static_cast< size_t >(0)) const
virtual const uint8_t * p() const
Definition BinaryStream.hpp:279
const T * read_array(size_t size) const
Definition BinaryStream.hpp:500
virtual uint64_t size() const =0
friend class ASN1Reader
Definition BinaryStream.hpp:36
result< std::u16string > peek_u16string_at(size_t offset, size_t length) const
bool can_read() const
Definition BinaryStream.hpp:484
ok_error_t read_objects(std::vector< T > &container, uint64_t count)
Definition BinaryStream.hpp:124
ok_error_t peek_objects_at(uint64_t offset, std::vector< T > &container, uint64_t count)
Definition BinaryStream.hpp:143
result< std::u16string > peek_u16string(size_t length) const
const T * cast() const
Definition BinaryStream.hpp:325
result< std::u16string > read_u16string() const
void set_endian_swap(bool swap)
Definition BinaryStream.hpp:265
bool is_memory_stream() const
Definition BinaryStream.hpp:57
const BinaryStream & increment_pos(size_t value) const
Definition BinaryStream.hpp:176
result< std::u16string > peek_u16string() const
bool should_swap() const
Definition BinaryStream.hpp:275
result< std::string > peek_string_at(size_t offset, size_t maxsize=~static_cast< size_t >(0)) const
ok_error_t peek_objects(std::vector< T > &container, uint64_t count)
Definition BinaryStream.hpp:138
size_t pos() const
Definition BinaryStream.hpp:189
virtual uint8_t * start()
Definition BinaryStream.hpp:283
result< uint64_t > read_uleb128(size_t *size=nullptr) const
virtual result< const void * > read_at(uint64_t offset, uint64_t size, uint64_t virtual_address=0) const =0
void setpos(size_t pos) const
Definition BinaryStream.hpp:172
bool is_valid() const
Definition BinaryStream.hpp:193
virtual const uint8_t * end() const
Definition BinaryStream.hpp:299
static bool is_all_zero(const T &buffer)
Definition BinaryStream.hpp:270
result< std::string > read_string(size_t maxsize=~static_cast< size_t >(0)) const
T * cast()
Definition BinaryStream.hpp:335
virtual ok_error_t peek_in(void *dst, uint64_t offset, uint64_t size, uint64_t virtual_address=0) const
Definition BinaryStream.hpp:305
result< std::u16string > read_u16string(size_t length) const
virtual ok_error_t peek_data(std::vector< uint8_t > &container, uint64_t offset, uint64_t size, uint64_t virtual_address=0)
Definition BinaryStream.hpp:82
void decrement_pos(size_t value) const
Definition BinaryStream.hpp:181
result< T > read() const
Definition BinaryStream.hpp:429
BinaryStream(STREAM_TYPE type)
Definition BinaryStream.hpp:48
virtual const uint8_t * start() const
Definition BinaryStream.hpp:295
result< uint64_t > read_sleb128(size_t *size=nullptr) const
ok_error_t read_array(std::array< T, N > &dst) const
Definition BinaryStream.hpp:228
bool can_read(int64_t offset, int64_t size) const
Definition BinaryStream.hpp:258
ok_error_t read_data(std::vector< uint8_t > &container)
Definition BinaryStream.hpp:118
virtual ~BinaryStream()=default
STREAM_TYPE type() const
Definition BinaryStream.hpp:53
virtual ok_error_t read_data(std::vector< uint8_t > &container, uint64_t size)
Definition BinaryStream.hpp:109
virtual uint8_t * end()
Definition BinaryStream.hpp:291
const BinaryStream & operator*() const
Definition BinaryStream.hpp:377
ScopedStream(BinaryStream &stream, uint64_t pos)
Definition BinaryStream.hpp:355
ScopedStream(BinaryStream &stream)
Definition BinaryStream.hpp:361
ScopedStream(const ScopedStream &)=delete
ScopedStream & operator=(const ScopedStream &)=delete
ScopedStream & operator=(ScopedStream &&)=delete
~ScopedStream()
Definition BinaryStream.hpp:365
BinaryStream & operator*()
Definition BinaryStream.hpp:373
ScopedStream(ScopedStream &&)=delete
BinaryStream * operator->()
Definition BinaryStream.hpp:369
ToggleEndianness(BinaryStream &stream, bool value)
Definition BinaryStream.hpp:394
ToggleEndianness(ToggleEndianness &&)=delete
ToggleEndianness & operator=(const ToggleEndianness &)=delete
ToggleEndianness & operator=(ToggleEndianness &&)=delete
BinaryStream & operator*()
Definition BinaryStream.hpp:414
BinaryStream * operator->()
Definition BinaryStream.hpp:410
ToggleEndianness(BinaryStream &stream)
Definition BinaryStream.hpp:400
~ToggleEndianness()
Definition BinaryStream.hpp:406
const BinaryStream & operator*() const
Definition BinaryStream.hpp:418
ToggleEndianness(const ToggleEndianness &)=delete
Opaque structure that is used by LIEF to avoid writing result<void> f(...). Instead,...
Definition errors.hpp:118
Wrapper that contains an Object (T) or an error.
Definition errors.hpp:78
#define LIEF_LIFETIMEBOUND
Definition compiler_attributes.hpp:72
@ read_error
Definition errors.hpp:25
@ inconsistent
Definition errors.hpp:43
tl::unexpected< lief_errors > make_error_code(lief_errors e)
Create a standard error code from lief_errors.
Definition errors.hpp:54
LIEF namespace.
Definition Abstract/Binary.hpp:40
ok_t ok()
Return success for function with return type ok_error_t.
Definition errors.hpp:102
void swap_endian(T *)
Definition endianness_support.hpp:117
#define LIEF_API
Definition visibility.h:45