Writes data to an internal memory buffer, which grows as required. More...
#include <juce_MemoryOutputStream.h>
Public Member Functions | |
MemoryOutputStream (size_t initialSize=256) | |
Creates an empty memory stream, ready to be written into. More... | |
MemoryOutputStream (MemoryBlock &memoryBlockToWriteTo, bool appendToExistingBlockContent) | |
Creates a memory stream for writing into into a pre-existing MemoryBlock object. More... | |
MemoryOutputStream (void *destBuffer, size_t destBufferSize) | |
Creates a MemoryOutputStream that will write into a user-supplied, fixed-size block of memory. More... | |
~MemoryOutputStream () | |
Destructor. More... | |
bool | appendUTF8Char (juce_wchar character) |
Appends the utf-8 bytes for a unicode character. More... | |
void | flush () override |
If the stream is writing to a user-supplied MemoryBlock, this will trim any excess capacity off the block, so that its length matches the amount of actual data that has been written so far. More... | |
const void * | getData () const noexcept |
Returns a pointer to the data that has been written to the stream. More... | |
size_t | getDataSize () const noexcept |
Returns the number of bytes of data that have been written to the stream. More... | |
MemoryBlock | getMemoryBlock () const |
Returns a copy of the stream's data as a memory block. More... | |
const String & | getNewLineString () const noexcept |
Returns the current new-line string that was set by setNewLineString(). More... | |
int64 | getPosition () override |
Returns the stream's current position. More... | |
void | preallocate (size_t bytesToPreallocate) |
Increases the internal storage capacity to be able to contain at least the specified amount of data without needing to be resized. More... | |
void | reset () noexcept |
Resets the stream, clearing any data that has been written to it so far. More... | |
void | setNewLineString (const String &newLineString) |
Sets the string to write to the stream when a new line is written. More... | |
bool | setPosition (int64) override |
Tries to move the stream's output position. More... | |
String | toString () const |
Attempts to detect the encoding of the data and convert it to a string. More... | |
String | toUTF8 () const |
Returns a String created from the (UTF8) data that has been written to the stream. More... | |
bool | write (const void *, size_t) override |
Writes a block of data to the stream. More... | |
virtual bool | writeBool (bool boolValue) |
Writes a boolean to the stream as a single byte. More... | |
virtual bool | writeByte (char byte) |
Writes a single byte to the stream. More... | |
virtual bool | writeCompressedInt (int value) |
Writes a condensed binary encoding of a 32-bit integer. More... | |
virtual bool | writeDouble (double value) |
Writes a 64-bit floating point value to the stream in a binary format. More... | |
virtual bool | writeDoubleBigEndian (double value) |
Writes a 64-bit floating point value to the stream in a binary format. More... | |
virtual bool | writeFloat (float value) |
Writes a 32-bit floating point value to the stream in a binary format. More... | |
virtual bool | writeFloatBigEndian (float value) |
Writes a 32-bit floating point value to the stream in a binary format. More... | |
int64 | writeFromInputStream (InputStream &, int64 maxNumBytesToWrite) override |
Reads data from an input stream and writes it to this stream. More... | |
virtual bool | writeInt (int value) |
Writes a 32-bit integer to the stream in a little-endian byte order. More... | |
virtual bool | writeInt64 (int64 value) |
Writes a 64-bit integer to the stream in a little-endian byte order. More... | |
virtual bool | writeInt64BigEndian (int64 value) |
Writes a 64-bit integer to the stream in a big-endian byte order. More... | |
virtual bool | writeIntBigEndian (int value) |
Writes a 32-bit integer to the stream in a big-endian byte order. More... | |
bool | writeRepeatedByte (uint8 byte, size_t numTimesToRepeat) override |
Writes a byte to the output stream a given number of times. More... | |
virtual bool | writeShort (short value) |
Writes a 16-bit integer to the stream in a little-endian byte order. More... | |
virtual bool | writeShortBigEndian (short value) |
Writes a 16-bit integer to the stream in a big-endian byte order. More... | |
virtual bool | writeString (const String &text) |
Stores a string in the stream in a binary format. More... | |
virtual bool | writeText (const String &text, bool asUTF16, bool writeUTF16ByteOrderMark) |
Writes a string of text to the stream. More... | |
Private Member Functions | |
char * | prepareToWrite (size_t) |
void | trimExternalBlockSize () |
Private Attributes | |
size_t | availableSize |
MemoryBlock *const | blockToUse |
void * | externalData |
MemoryBlock | internalBlock |
size_t | position |
size_t | size |
Writes data to an internal memory buffer, which grows as required.
The data that was written into the stream can then be accessed later as a contiguous block of memory.
MemoryOutputStream::MemoryOutputStream | ( | size_t | initialSize = 256 | ) |
Creates an empty memory stream, ready to be written into.
initialSize | the intial amount of capacity to allocate for writing into |
MemoryOutputStream::MemoryOutputStream | ( | MemoryBlock & | memoryBlockToWriteTo, |
bool | appendToExistingBlockContent | ||
) |
Creates a memory stream for writing into into a pre-existing MemoryBlock object.
Note that the destination block will always be larger than the amount of data that has been written to the stream, because the MemoryOutputStream keeps some spare capactity at its end. To trim the block's size down to fit the actual data, call flush(), or delete the MemoryOutputStream.
memoryBlockToWriteTo | the block into which new data will be written. |
appendToExistingBlockContent | if this is true, the contents of the block will be kept, and new data will be appended to it. If false, the block will be cleared before use |
MemoryOutputStream::MemoryOutputStream | ( | void * | destBuffer, |
size_t | destBufferSize | ||
) |
Creates a MemoryOutputStream that will write into a user-supplied, fixed-size block of memory.
When using this mode, the stream will write directly into this memory area until it's full, at which point write operations will fail.
MemoryOutputStream::~MemoryOutputStream | ( | ) |
Destructor.
This will free any data that was written to it.
bool MemoryOutputStream::appendUTF8Char | ( | juce_wchar | character | ) |
Appends the utf-8 bytes for a unicode character.
|
overridevirtual |
If the stream is writing to a user-supplied MemoryBlock, this will trim any excess capacity off the block, so that its length matches the amount of actual data that has been written so far.
Implements OutputStream.
|
noexcept |
Returns a pointer to the data that has been written to the stream.
|
inlinenoexcept |
Returns the number of bytes of data that have been written to the stream.
References OutputStream::flush(), toString(), and OutputStream::write().
MemoryBlock MemoryOutputStream::getMemoryBlock | ( | ) | const |
Returns a copy of the stream's data as a memory block.
|
inlinenoexceptinherited |
Returns the current new-line string that was set by setNewLineString().
|
inlineoverridevirtual |
Returns the stream's current position.
Implements OutputStream.
References OutputStream::setPosition(), OutputStream::writeFromInputStream(), and OutputStream::writeRepeatedByte().
void MemoryOutputStream::preallocate | ( | size_t | bytesToPreallocate | ) |
Increases the internal storage capacity to be able to contain at least the specified amount of data without needing to be resized.
|
private |
|
noexcept |
Resets the stream, clearing any data that has been written to it so far.
|
inherited |
Sets the string to write to the stream when a new line is written.
By default this will be set the value of NewLine::getDefault().
|
overridevirtual |
Tries to move the stream's output position.
Not all streams will be able to seek to a new position - this will return false if it fails to work.
Implements OutputStream.
String MemoryOutputStream::toString | ( | ) | const |
Attempts to detect the encoding of the data and convert it to a string.
Referenced by CppTokeniserFunctions::addEscapeChars().
String MemoryOutputStream::toUTF8 | ( | ) | const |
Returns a String created from the (UTF8) data that has been written to the stream.
|
private |
|
overridevirtual |
Writes a block of data to the stream.
When creating a subclass of OutputStream, this is the only write method that needs to be overloaded - the base class has methods for writing other types of data which use this to do the work.
dataToWrite | the target buffer to receive the data. This must not be null. |
numberOfBytes | the number of bytes to write. |
Implements OutputStream.
|
virtualinherited |
Writes a boolean to the stream as a single byte.
This is encoded as a binary byte (not as text) with a value of 1 or 0.
|
virtualinherited |
Writes a single byte to the stream.
|
virtualinherited |
Writes a condensed binary encoding of a 32-bit integer.
If you're storing a lot of integers which are unlikely to have very large values, this can save a lot of space, because values under 0xff will only take up 2 bytes, under 0xffff only 3 bytes, etc.
The format used is: number of significant bytes + up to 4 bytes in little-endian order.
|
virtualinherited |
Writes a 64-bit floating point value to the stream in a binary format.
The eight raw bytes of the double value are written out as a little-endian 64-bit int.
|
virtualinherited |
Writes a 64-bit floating point value to the stream in a binary format.
The eight raw bytes of the double value are written out as a big-endian 64-bit int.
|
virtualinherited |
Writes a 32-bit floating point value to the stream in a binary format.
The binary 32-bit encoding of the float is written as a little-endian int.
|
virtualinherited |
Writes a 32-bit floating point value to the stream in a binary format.
The binary 32-bit encoding of the float is written as a big-endian int.
|
overridevirtual |
Reads data from an input stream and writes it to this stream.
source | the stream to read from |
maxNumBytesToWrite | the number of bytes to read from the stream (if this is less than zero, it will keep reading until the input is exhausted) |
Reimplemented from OutputStream.
|
virtualinherited |
Writes a 32-bit integer to the stream in a little-endian byte order.
|
virtualinherited |
Writes a 64-bit integer to the stream in a little-endian byte order.
|
virtualinherited |
Writes a 64-bit integer to the stream in a big-endian byte order.
|
virtualinherited |
Writes a 32-bit integer to the stream in a big-endian byte order.
|
overridevirtual |
Writes a byte to the output stream a given number of times.
Reimplemented from OutputStream.
|
virtualinherited |
Writes a 16-bit integer to the stream in a little-endian byte order.
This will write two bytes to the stream: (value & 0xff), then (value >> 8).
|
virtualinherited |
Writes a 16-bit integer to the stream in a big-endian byte order.
This will write two bytes to the stream: (value >> 8), then (value & 0xff).
|
virtualinherited |
Stores a string in the stream in a binary format.
This isn't the method to use if you're trying to append text to the end of a text-file! It's intended for storing a string so that it can be retrieved later by InputStream::readString().
It writes the string to the stream as UTF8, including the null termination character.
For appending text to a file, instead use writeText, or operator<<
|
virtualinherited |
Writes a string of text to the stream.
It can either write the text as UTF-8 or UTF-16, and can also add the UTF-16 byte-order-mark bytes (0xff, 0xfe) to indicate the endianness (these should only be used at the start of a file).
The method also replaces '\n' characters in the text with '\r\n'.
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |