JUCE
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Defines
Public Member Functions
FileOutputStream Class Reference

An output stream that writes into a local file. More...

Inherits OutputStream.

List of all members.

Public Member Functions

 FileOutputStream (const File &fileToWriteTo, int bufferSizeToUse=16384)
 Creates a FileOutputStream.
 ~FileOutputStream ()
 Destructor.
const FilegetFile () const
 Returns the file that this stream is writing to.
const ResultgetStatus () const noexcept
 Returns the status of the file stream.
bool failedToOpen () const noexcept
 Returns true if the stream couldn't be opened for some reason.
bool openedOk () const noexcept
 Returns true if the stream opened without problems.
Result truncate ()
 Attempts to truncate the file to the current write position.
void flush ()
 If the stream is using a buffer, this will ensure it gets written out to the destination.
int64 getPosition ()
 Returns the stream's current position.
bool setPosition (int64 pos)
 Tries to move the stream's output position.
bool write (const void *data, int numBytes)
 Writes a block of data to the stream.
void writeRepeatedByte (uint8 byte, int numTimesToRepeat)
 Writes a byte to the output stream a given number of times.

Detailed Description

An output stream that writes into a local file.

See also:
OutputStream, FileInputStream, File::createOutputStream

Constructor & Destructor Documentation

FileOutputStream::FileOutputStream ( const File fileToWriteTo,
int  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, the failedToOpen() method will return true.

If the file already exists when opened, the stream's write-postion will be set to the end of the file. To overwrite an existing file, use File::deleteFile() before opening the stream, or use setPosition(0) after it's opened (although this won't truncate the file).

See also:
TemporaryFile

Destructor.


Member Function Documentation

const File& FileOutputStream::getFile ( ) const

Returns the file that this stream is writing to.

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.

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

See also:
getResult()

Returns true if the stream opened without problems.

See also:
getResult()

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.

void FileOutputStream::flush ( ) [virtual]

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

Implements OutputStream.

Returns the stream's current position.

See also:
setPosition

Implements OutputStream.

bool FileOutputStream::setPosition ( int64  newPosition) [virtual]

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 OutputStream.

bool FileOutputStream::write ( const void *  dataToWrite,
int  numberOfBytes 
) [virtual]

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. This must not be negative.
Returns:
false if the write operation fails for some reason

Implements OutputStream.

void FileOutputStream::writeRepeatedByte ( uint8  byte,
int  numTimesToRepeat 
) [virtual]

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

Reimplemented from OutputStream.


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