casacore
|
Class for buffered IO on a file. More...
#include <FilebufIO.h>
Public Member Functions | |
FilebufIO () | |
Default constructor. More... | |
FilebufIO (int fd, uInt bufferSize=16384) | |
Construct from the given file descriptor. More... | |
void | attach (int fd, uInt bufferSize=16384) |
Attach to the given file descriptor. More... | |
virtual | ~FilebufIO () |
The destructor closes the file when it was owned and opened and not closed yet. More... | |
virtual void | write (Int64 size, const void *buf) |
Write the number of bytes. More... | |
virtual Int64 | read (Int64 size, void *buf, Bool throwException=True) |
Read size bytes from the File. More... | |
virtual void | flush () |
Flush the current buffer. More... | |
virtual void | resync () |
Resync the file (i.e. More... | |
virtual Int64 | length () |
Get the length of the byte stream. More... | |
virtual Bool | isReadable () const |
Is the IO stream readable? More... | |
virtual Bool | isWritable () const |
Is the IO stream writable? More... | |
virtual Bool | isSeekable () const |
Is the IO stream seekable? More... | |
virtual String | fileName () const |
Get the file name of the file attached. More... | |
uInt | bufferSize () const |
Get the buffer size. More... | |
Public Member Functions inherited from casacore::ByteIO | |
ByteIO () | |
The constructor does nothing. More... | |
virtual | ~ByteIO () |
virtual void | pwrite (Int64 size, Int64 offset, const void *buf) |
Write size bytes to the byte stream at offset . More... | |
virtual Int64 | pread (Int64 size, Int64 offset, void *buf, Bool throwException=True) |
Like read but reads from offset of start of the file The file offset is not changed. More... | |
virtual void | reopenRW () |
Reopen the underlying IO stream for read/write access. More... | |
Int64 | seek (Int offset, ByteIO::SeekOption=ByteIO::Begin) |
This function sets the position on the given offset. More... | |
Int64 | seek (Int64 offset, ByteIO::SeekOption=ByteIO::Begin) |
virtual void | fsync () |
Fsync the file (i.e. More... | |
Protected Member Functions | |
void | detach (Bool closeFile=False) |
Detach the FILE. More... | |
void | fillRWFlags (int fd) |
Determine if the file descriptor is readable and/or writable. More... | |
void | fillSeekable () |
Determine if the file is seekable. More... | |
virtual Int64 | doSeek (Int64 offset, ByteIO::SeekOption) |
Reset the position pointer to the given value. More... | |
void | setBuffer (Int64 bufSize) |
Set a new buffer size. More... | |
void | writeBuffer (Int64 offset, const char *buf, Int64 size) |
Write a buffer of given length into the file at given offset. More... | |
Int64 | readBuffer (Int64 offset, char *buf, Int64 size, Bool throwException) |
Read a buffer of given length from the file at given offset. More... | |
void | writeBlock (Int64 size, const char *buf) |
Write a block into the stream at the current offset. More... | |
Int64 | readBlock (Int64 size, char *buf, Bool throwException) |
Read a block from the stream at the current offset. More... | |
Protected Member Functions inherited from casacore::ByteIO | |
ByteIO (const ByteIO &byteIO) | |
Make copy constructor and assignment protected, so a user cannot use them (but a derived class can). More... | |
ByteIO & | operator= (const ByteIO &byteIO) |
Private Member Functions | |
FilebufIO (const FilebufIO &that) | |
Copy constructor, should not be used. More... | |
FilebufIO & | operator= (const FilebufIO &that) |
Assignment, should not be used. More... | |
Private Attributes | |
Bool | itsSeekable |
Bool | itsReadable |
Bool | itsWritable |
int | itsFile |
Int64 | itsBufSize |
Int64 | itsBufLen |
char * | itsBuffer |
Int64 | itsBufOffset |
Int64 | itsOffset |
Int64 | itsSeekOffset |
Bool | itsDirty |
Additional Inherited Members | |
Public Types inherited from casacore::ByteIO | |
enum | OpenOption { Old, Update, Append, New, NewNoReplace, Scratch, Delete } |
Define the possible ByteIO open options. More... | |
enum | SeekOption { Begin, Current, End } |
Define the possible seek options. More... | |
Class for buffered IO on a file.
Public interface
This class is a specialization of class ByteIO. This class is doing IO on a file in a buffered way to reduce the number of file accesses as much as possible. It is part of the entire IO framework. It can for instance be used to store data in canonical format in a file in an IO-efficient way
The buffer size is dynamic, so any time it can be set as needed.
It is also possible to construct a FilebufIO
object from a file descriptor (e.g. for a pipe or socket). The constructor will determine automatically if the file is readable, writable and seekable.
This example shows how FilebufIO can be used with an fd. It uses the fd for a regular file, which could be done in an easier way using class RegularFileIO. However, when using pipes or sockets, this would be the only way.
The stdio package was used, but it proved to be very slow on SOlaris. After a seek the buffer was refreshed, which increased the number of file accesses enormously. Also the interaction between reads and writes in stdio was poor.
Definition at line 94 of file FilebufIO.h.
casacore::FilebufIO::FilebufIO | ( | ) |
Default constructor.
A stream can be attached using the attach function.
|
explicit |
Construct from the given file descriptor.
Note that the destructor and the detach function implicitly close the file descriptor.
|
virtual |
The destructor closes the file when it was owned and opened and not closed yet.
|
private |
Copy constructor, should not be used.
void casacore::FilebufIO::attach | ( | int | fd, |
uInt | bufferSize = 16384 |
||
) |
Attach to the given file descriptor.
Note that the destructor and the detach function implicitly close the file descriptor.
|
inline |
Detach the FILE.
Close it when needed.
|
protectedvirtual |
Reset the position pointer to the given value.
It returns the new position.
Implements casacore::ByteIO.
|
virtual |
Get the file name of the file attached.
Reimplemented from casacore::ByteIO.
Reimplemented in casacore::RegularFileIO.
|
protected |
Determine if the file descriptor is readable and/or writable.
|
protected |
Determine if the file is seekable.
|
virtual |
Flush the current buffer.
Reimplemented from casacore::ByteIO.
|
virtual |
Is the IO stream readable?
Implements casacore::ByteIO.
|
virtual |
Is the IO stream seekable?
Implements casacore::ByteIO.
|
virtual |
Is the IO stream writable?
Implements casacore::ByteIO.
|
virtual |
Get the length of the byte stream.
Implements casacore::ByteIO.
Assignment, should not be used.
|
virtual |
Read size
bytes from the File.
Returns the number of bytes actually read. Will throw an exception (AipsError) if the requested number of bytes could not be read unless throwException is set to False. Will always throw an exception if the file is not readable or the system call returns an undocumented value.
Implements casacore::ByteIO.
Read a block from the stream at the current offset.
It is guaranteed that the block fits in a single buffer.
|
protected |
Read a buffer of given length from the file at given offset.
|
virtual |
|
protected |
Set a new buffer size.
If a buffer was already existing, flush and delete it.
|
virtual |
Write the number of bytes.
Implements casacore::ByteIO.
|
protected |
Write a block into the stream at the current offset.
It is guaranteed that the block fits in a single buffer.
Write a buffer of given length into the file at given offset.
|
private |
Definition at line 190 of file FilebufIO.h.
|
private |
Definition at line 189 of file FilebufIO.h.
|
private |
Definition at line 191 of file FilebufIO.h.
|
private |
Definition at line 188 of file FilebufIO.h.
Referenced by bufferSize().
|
private |
Definition at line 194 of file FilebufIO.h.
|
private |
Definition at line 187 of file FilebufIO.h.
|
private |
Definition at line 192 of file FilebufIO.h.
|
private |
Definition at line 185 of file FilebufIO.h.
|
private |
Definition at line 184 of file FilebufIO.h.
|
private |
Definition at line 193 of file FilebufIO.h.
|
private |
Definition at line 186 of file FilebufIO.h.