/**
Destructor.
*/
- ~wxCountingOutputStream();
+ virtual ~wxCountingOutputStream();
/**
Returns the current size of the stream.
/**
Constructor; creates a new empty stream buffer which won't flush any data
to a stream. mode specifies the type of the buffer (read, write, read_write).
+
This stream buffer has the advantage to be stream independent and to work
only on memory buffers but it is still compatible with the rest of the
wxStream classes. You can write, read to this special stream and it will
wxStreamBuffer(BufMode mode);
/**
- Constructor. It initializes the stream buffer with the data of the specified
+ Constructor.
+
+ This method initializes the stream buffer with the data of the specified
stream buffer. The new stream buffer has the same attributes, size, position
and they share the same buffer. This will cause problems if the stream to
which the stream buffer belong is destroyed and the newly cloned stream
@see Read()
*/
- char GetChar();
+ virtual char GetChar();
/**
Returns the amount of available data in the buffer.
/**
Returns the current position (counted in bytes) in the stream buffer.
*/
- off_t GetIntPosition() const;
+ wxFileOffset GetIntPosition() const;
/**
Returns the amount of bytes read during the last IO call to the parent stream.
@see Read()
*/
- void PutChar(char c);
+ virtual void PutChar(char c);
/**
Reads a block of the specified size and stores the data in buffer.
different of the specified size, an error has occurred and
should be tested using GetLastError().
*/
- size_t Read(void* buffer, size_t size);
+ virtual size_t Read(void* buffer, size_t size);
/**
Copies data to @a buffer.
measured in bytes from the beginning of the stream.
Otherwise, it returns wxInvalidOffset.
*/
- off_t Seek(off_t pos, wxSeekMode mode);
+ virtual wxFileOffset Seek(wxFileOffset pos, wxSeekMode mode);
/**
Specifies which pointers to use for stream buffering.
@return Returns the current position in the stream if possible,
wxInvalidOffset in the other case.
*/
- off_t Tell() const;
+ virtual wxFileOffset Tell() const;
/**
Truncates the buffer to the current position.
Writes a block of the specified size using data of buffer.
The data are cached in a buffer before being sent in one block to the stream.
*/
- size_t Write(const void* buffer, size_t size);
+ virtual size_t Write(const void* buffer, size_t size);
/**
See Read().
/**
Destructor.
*/
- ~wxOutputStream();
+ virtual ~wxOutputStream();
/**
Closes the stream, returning @false if an error occurs.
as a file, then the underlying resource is closed too if it is owned
by this stream, or left open otherwise.
*/
- bool Close();
+ virtual bool Close();
/**
Returns the number of bytes written during the last Write().
It may return 0 even if there is no error on the stream if it is
only temporarily impossible to write to it.
*/
- size_t LastWrite() const;
+ virtual size_t LastWrite() const;
/**
Puts the specified character in the output queue and increments the
@return The new stream position or wxInvalidOffset on error.
*/
- off_t SeekO(off_t pos, wxSeekMode mode = wxFromStart);
+ virtual wxFileOffset SeekO(wxFileOffset pos, wxSeekMode mode = wxFromStart);
/**
Returns the current stream position.
*/
- off_t TellO() const;
+ virtual wxFileOffset TellO() const;
/**
Writes up to the specified amount of bytes using the data of buffer.
handle it and create a stream to decompress it:
@code
- factory = wxFilterClassFactory::Find(filename, wxSTREAM_FILEEXT);
+ factory = wxFilterClassFactory::Find(filename, wxSTREAM_FILEEXT);
if (factory)
stream = factory-NewStream(new wxFFileInputStream(filename));
@endcode
list << *p << _T("\n");
@endcode
*/
- const wxChar* const* GetProtocols(wxStreamProtocolType type = wxSTREAM_PROTOCOL) const;
+ virtual const wxChar * const* GetProtocols(wxStreamProtocolType type = wxSTREAM_PROTOCOL) const = 0;
//@{
/**
/**
Destructor.
*/
- ~wxInputStream();
+ virtual ~wxInputStream();
/**
Returns @true if some data is available in the stream right now, so that
calling Read() wouldn't block.
*/
- bool CanRead() const;
+ virtual bool CanRead() const;
/**
Returns @true after an attempt has been made to read past the end of the
stream.
*/
- bool Eof() const;
+ virtual bool Eof() const;
/**
Returns the first character in the input queue and removes it,
/**
Returns the last number of bytes read.
*/
- size_t LastRead() const;
+ virtual size_t LastRead() const;
/**
Returns the first character in the input queue without removing it.
*/
- char Peek();
+ virtual char Peek();
/**
Reads the specified amount of bytes and stores the data in buffer.
@return The new stream position or wxInvalidOffset on error.
*/
- off_t SeekI(off_t pos, wxSeekMode mode = wxFromStart);
+ virtual wxFileOffset SeekI(wxFileOffset pos, wxSeekMode mode = wxFromStart);
/**
Returns the current stream position.
*/
- off_t TellI() const;
+ virtual wxFileOffset TellI() const;
/**
This function is only useful in read mode.
/**
Destructor.
*/
- ~wxStreamBase();
+ virtual ~wxStreamBase();
/**
This function returns the last error.
@since 2.5.4
*/
- wxFileOffset GetLength() const;
+ virtual wxFileOffset GetLength() const;
/**
This function returns the size of the stream.
streams. In that cases, GetSize returns 0 so you should always test its
return value.
*/
- size_t GetSize() const;
+ virtual size_t GetSize() const;
/**
Returns @true if no error occurred on the stream.
/**
Returns @true if the streams supports seeking to arbitrary offsets.
*/
- bool IsSeekable() const;
+ virtual bool IsSeekable() const;
/**
Internal function. It is called when the stream wants to read data of the
size_t OnSysRead(void* buffer, size_t bufsize);
/**
- Internal function.
- It is called when the stream needs to change the current position.
+ See OnSysRead().
*/
- off_t OnSysSeek(off_t pos, wxSeekMode mode);
+ size_t OnSysWrite(const void* buffer, size_t bufsize);
+
+
+protected:
/**
Internal function.
- It is called when the stream needs to know the real position.
+ It is called when the stream needs to change the current position.
*/
- off_t OnSysTell() const;
+ virtual wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode);
/**
- See OnSysRead().
+ Internal function.
+ It is called when the stream needs to know the real position.
*/
- size_t OnSysWrite(const void* buffer, size_t bufsize);
+ virtual wxFileOffset OnSysTell() const;
};