Inherited by ost::MappedFile, ost::SharedFile, and ost::ThreadFile.
Public Member Functions
virtual ~RandomFile ()
Destroy a random access file or it's derived class.
bool initial (void)
This method should be called right after a RandomFile derived object has been created.
off_t getCapacity (void)
Get current file capacity.
virtual Errorrestart (void)
This method is commonly used to close and re-open an existing database. ErrorgetErrorNumber (void)
Return current error id.
char * getErrorString (void)
Return current error string.
bool operator! (void)
Protected Member Functions
RandomFile (const char *name=NULL)
Create an unopened random access file. RandomFile (const RandomFile &rf)
Default copy constructor. Errorerror (Error errid, char *errstr=NULL)
Post an error event. Errorerror (char *err)
Post an extended string error message.
void setError (bool enable)
Used to enable or disable throwing of exceptions on errors. ErrorsetCompletion (Complete mode)
Used to set file completion modes.
void setTemporary (bool enable)
Used to set the temporary attribute for the file.
virtual Attrinitialize (void)
This method is used to initialize a newly created file as indicated by the 'initial' flag.
void final (void)
Close the file.
Protected Attributes
int fd
Accessaccess
char * pathname
struct {
unsigned count: 16
bool thrown: 1
bool initial: 1
bool immediate: 1
bool temp: 1
} flags
Related Functions
(Note that these are not member functions.)
bool isDir (const char *path)
bool isFile (const char *path)
bool isDevice (const char *path)
bool canAccess (const char *path)
bool canModify (const char *path)
time_t lastModified (const char *path)
time_t lastAccessed (const char *path)
Detailed Description
The purpose of this class is to define a base class for low level random file access that is portable between Win32 and Posix systems.
This class is a foundation both for optimized thread shared and traditional locked file access that is commonly used to build database services, rather than the standard C++ streaming file classes.
Author:
David Sugar <dyfet@ostel.com> Portable random disk file access.
Constructor & Destructor Documentation
ost::RandomFile::RandomFile (const char * name = NULL) [protected]
This method should be called right after a RandomFile derived object has been created. This method will invoke initialize if the object is newly created, and set file access permissions appropriately.
This method is used to initialize a newly created file as indicated by the 'initial' flag. This method also returns the file access permissions that should be associated with the file. This method should never be called directly, but is instead used to impliment the 'Initial' method. Typically one would use this to build an empty database shell when a previously empty database file is created.
This method is commonly used to close and re-open an existing database. This may be used when the database has been unlinked and an external process provides a new one to use.
Reimplemented in ost::ThreadFile, and ost::SharedFile.