LLVM 22.0.0git
llvm::BinaryByteStream Class Reference

An implementation of BinaryStream which holds its entire data set in a single contiguous buffer. More...

#include "llvm/Support/BinaryByteStream.h"

Inheritance diagram for llvm::BinaryByteStream:
[legend]

Public Member Functions

 BinaryByteStream ()=default
 BinaryByteStream (ArrayRef< uint8_t > Data, llvm::endianness Endian)
 BinaryByteStream (StringRef Data, llvm::endianness Endian)
llvm::endianness getEndian () const override
Error readBytes (uint64_t Offset, uint64_t Size, ArrayRef< uint8_t > &Buffer) override
 Given an offset into the stream and a number of bytes, attempt to read the bytes and set the output ArrayRef to point to data owned by the stream.
Error readLongestContiguousChunk (uint64_t Offset, ArrayRef< uint8_t > &Buffer) override
 Given an offset into the stream, read as much as possible without copying any data.
uint64_t getLength () override
 Return the number of bytes of data in this stream.
ArrayRef< uint8_tdata () const
StringRef str () const
Public Member Functions inherited from llvm::BinaryStream
virtual ~BinaryStream ()=default
virtual BinaryStreamFlags getFlags () const
 Return the properties of this stream.

Protected Attributes

llvm::endianness Endian
ArrayRef< uint8_tData

Additional Inherited Members

Protected Member Functions inherited from llvm::BinaryStream
Error checkOffsetForRead (uint64_t Offset, uint64_t DataSize)

Detailed Description

An implementation of BinaryStream which holds its entire data set in a single contiguous buffer.

BinaryByteStream guarantees that no read operation will ever incur a copy. Note that BinaryByteStream does not own the underlying buffer.

Definition at line 30 of file BinaryByteStream.h.

Constructor & Destructor Documentation

◆ BinaryByteStream() [1/3]

llvm::BinaryByteStream::BinaryByteStream ( )
default

◆ BinaryByteStream() [2/3]

llvm::BinaryByteStream::BinaryByteStream ( ArrayRef< uint8_t > Data,
llvm::endianness Endian )
inline

Definition at line 33 of file BinaryByteStream.h.

References Data, and Endian.

◆ BinaryByteStream() [3/3]

llvm::BinaryByteStream::BinaryByteStream ( StringRef Data,
llvm::endianness Endian )
inline

Definition at line 35 of file BinaryByteStream.h.

References Data, and Endian.

Member Function Documentation

◆ data()

ArrayRef< uint8_t > llvm::BinaryByteStream::data ( ) const
inline

Definition at line 58 of file BinaryByteStream.h.

References Data.

◆ getEndian()

llvm::endianness llvm::BinaryByteStream::getEndian ( ) const
inlineoverridevirtual

Implements llvm::BinaryStream.

Definition at line 38 of file BinaryByteStream.h.

References Endian.

◆ getLength()

uint64_t llvm::BinaryByteStream::getLength ( )
inlineoverridevirtual

Return the number of bytes of data in this stream.

Implements llvm::BinaryStream.

Definition at line 56 of file BinaryByteStream.h.

References Data.

◆ readBytes()

Error llvm::BinaryByteStream::readBytes ( uint64_t Offset,
uint64_t Size,
ArrayRef< uint8_t > & Buffer )
inlineoverridevirtual

Given an offset into the stream and a number of bytes, attempt to read the bytes and set the output ArrayRef to point to data owned by the stream.

Implements llvm::BinaryStream.

Definition at line 40 of file BinaryByteStream.h.

References llvm::BinaryStream::checkOffsetForRead(), Data, llvm::Offset, Size, and llvm::Error::success().

◆ readLongestContiguousChunk()

Error llvm::BinaryByteStream::readLongestContiguousChunk ( uint64_t Offset,
ArrayRef< uint8_t > & Buffer )
inlineoverridevirtual

Given an offset into the stream, read as much as possible without copying any data.

Implements llvm::BinaryStream.

Definition at line 48 of file BinaryByteStream.h.

References llvm::BinaryStream::checkOffsetForRead(), Data, llvm::Offset, and llvm::Error::success().

◆ str()

StringRef llvm::BinaryByteStream::str ( ) const
inline

Definition at line 60 of file BinaryByteStream.h.

References Data.

Member Data Documentation

◆ Data

ArrayRef<uint8_t> llvm::BinaryByteStream::Data
protected

◆ Endian

llvm::endianness llvm::BinaryByteStream::Endian
protected

The documentation for this class was generated from the following file: