LMMS
Loading...
Searching...
No Matches
juce::FileOutputStream Class Reference

#include <juce_FileOutputStream.h>

Inheritance diagram for juce::FileOutputStream:
juce::OutputStream

Public Member Functions

 FileOutputStream (const File &fileToWriteTo, size_t bufferSizeToUse=16384)
 ~FileOutputStream () override
const FilegetFile () const
const ResultgetStatus () const noexcept
bool failedToOpen () const noexcept
bool openedOk () const noexcept
Result truncate ()
void flush () override
int64 getPosition () override
bool setPosition (int64) override
bool write (const void *, size_t) override
bool writeRepeatedByte (uint8 byte, size_t numTimesToRepeat) override
Public Member Functions inherited from juce::OutputStream
virtual ~OutputStream ()
virtual bool writeByte (char byte)
virtual bool writeBool (bool boolValue)
virtual bool writeShort (short value)
virtual bool writeShortBigEndian (short value)
virtual bool writeInt (int value)
virtual bool writeIntBigEndian (int value)
virtual bool writeInt64 (int64 value)
virtual bool writeInt64BigEndian (int64 value)
virtual bool writeFloat (float value)
virtual bool writeFloatBigEndian (float value)
virtual bool writeDouble (double value)
virtual bool writeDoubleBigEndian (double value)
virtual bool writeCompressedInt (int value)
virtual bool writeString (const String &text)
virtual bool writeText (const String &text, bool asUTF16, bool writeUTF16ByteOrderMark, const char *lineEndings)
virtual int64 writeFromInputStream (InputStream &source, int64 maxNumBytesToWrite)
void setNewLineString (const String &newLineString)
const StringgetNewLineString () const noexcept

Private Member Functions

void openHandle ()
void closeHandle ()
void flushInternal ()
bool flushBuffer ()
int64 setPositionInternal (int64)
ssize_t writeInternal (const void *, size_t)

Private Attributes

File file
voidfileHandle = nullptr
Result status { Result::ok() }
int64 currentPosition = 0
size_t bufferSize
size_t bytesInBuffer = 0
HeapBlock< char > buffer

Additional Inherited Members

Protected Member Functions inherited from juce::OutputStream
 OutputStream ()

Detailed Description

An output stream that writes into a local file.

See also
OutputStream, FileInputStream, File::createOutputStream

@tags{Core}

Constructor & Destructor Documentation

◆ FileOutputStream()

juce::FileOutputStream::FileOutputStream ( const File & fileToWriteTo,
size_t bufferSizeToUse = 16384 )

Creates a FileOutputStream.

If the file doesn't exist, it will first be created. If the file can't be created or opened (for example, because the parent directory of the file does not exist), the failedToOpen() method will return true.

If the file already exists when opened, the stream's write-position will be set to the end of the file. To overwrite an existing file, you can truncate it like this:

if (stream.openedOk())
{
stream.setPosition (0);
stream.truncate();
...
}
File file
Definition juce_FileOutputStream.h:109
FileOutputStream(const File &fileToWriteTo, size_t bufferSizeToUse=16384)
Definition juce_FileOutputStream.cpp:27

Destroying a FileOutputStream object does not force the operating system to write the buffered data to disk immediately. If this is required you should call flush() before triggering the destructor.

See also
TemporaryFile

◆ ~FileOutputStream()

juce::FileOutputStream::~FileOutputStream ( )
override

Destructor.

Member Function Documentation

◆ closeHandle()

void juce::FileOutputStream::closeHandle ( )
private

◆ failedToOpen()

bool juce::FileOutputStream::failedToOpen ( ) const
inlinenoexcept

Returns true if the stream couldn't be opened for some reason.

See also
getResult()

◆ flush()

void juce::FileOutputStream::flush ( )
overridevirtual

If the stream is using a buffer, this will ensure it gets written out to the destination.

Implements juce::OutputStream.

◆ flushBuffer()

bool juce::FileOutputStream::flushBuffer ( )
private

◆ flushInternal()

void juce::FileOutputStream::flushInternal ( )
private

◆ getFile()

const File & juce::FileOutputStream::getFile ( ) const
inline

Returns the file that this stream is writing to.

◆ getPosition()

int64 juce::FileOutputStream::getPosition ( )
overridevirtual

Returns the stream's current position.

See also
setPosition

Implements juce::OutputStream.

◆ getStatus()

const Result & juce::FileOutputStream::getStatus ( ) const
inlinenoexcept

Returns the status of the file stream. The result will be ok if the file opened successfully. If an error occurs while opening or writing to the file, this will contain an error message.

◆ openedOk()

bool juce::FileOutputStream::openedOk ( ) const
inlinenoexcept

Returns true if the stream opened without problems.

See also
getResult()

◆ openHandle()

void juce::FileOutputStream::openHandle ( )
private

◆ setPosition()

bool juce::FileOutputStream::setPosition ( int64 newPosition)
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.

See also
getPosition

Implements juce::OutputStream.

◆ setPositionInternal()

int64 juce::FileOutputStream::setPositionInternal ( int64 )
private

◆ truncate()

Result juce::FileOutputStream::truncate ( )

Attempts to truncate the file to the current write position. To truncate a file to a specific size, first use setPosition() to seek to the appropriate location, and then call this method.

◆ write()

bool juce::FileOutputStream::write ( const void * dataToWrite,
size_t numberOfBytes )
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.

Parameters
dataToWritethe target buffer to receive the data. This must not be null.
numberOfBytesthe number of bytes to write.
Returns
false if the write operation fails for some reason

Implements juce::OutputStream.

◆ writeInternal()

ssize_t juce::FileOutputStream::writeInternal ( const void * data,
size_t numBytes )
private

◆ writeRepeatedByte()

bool juce::FileOutputStream::writeRepeatedByte ( uint8 byte,
size_t numTimesToRepeat )
overridevirtual

Writes a byte to the output stream a given number of times.

Returns
false if the write operation fails for some reason

Reimplemented from juce::OutputStream.

Member Data Documentation

◆ buffer

HeapBlock<char> juce::FileOutputStream::buffer
private

◆ bufferSize

size_t juce::FileOutputStream::bufferSize
private

◆ bytesInBuffer

size_t juce::FileOutputStream::bytesInBuffer = 0
private

◆ currentPosition

int64 juce::FileOutputStream::currentPosition = 0
private

◆ file

File juce::FileOutputStream::file
private

◆ fileHandle

void* juce::FileOutputStream::fileHandle = nullptr
private

◆ status

Result juce::FileOutputStream::status { Result::ok() }
private

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