My Project
|
The Store is a file based memory manager. More...
#include <store.h>
Classes | |
struct | Node |
Public Member Functions | |
Store () | |
~Store () | |
int | open (const char *name) |
portable_off_t | alloc () |
int | write (const char *buf, uint size) |
void | end () |
void | release (portable_off_t handle) |
void | close () |
void | seek (portable_off_t handle) |
int | read (char *buf, uint size) |
void | printStats () |
portable_off_t | pos () const |
void | dumpBlock (portable_off_t start, portable_off_t end) |
Public Member Functions inherited from StorageIntf | |
virtual | ~StorageIntf () |
Private Types | |
enum | State { Init, Reading, Writing } |
Private Member Functions | |
void | printFreeList () |
Private Attributes | |
FILE * | m_file |
portable_off_t | m_front |
portable_off_t | m_cur |
Node * | m_head |
State | m_state |
int | m_reads |
int | m_writes |
The Store is a file based memory manager.
You can open the store using open(). Then obtain a handle via alloc() followed by a sequence of write() commands to store information, and finalize it using end().
Later on you locate the information with seek() using the handle obtained with alloc(), and then use a sequence of read() calls to read the information back.
If no longer needed the storage space can be freed using release().
The store will dynamically grow the file on disk if needed.
|
private |
Store::Store | ( | ) |
Store::~Store | ( | ) |
portable_off_t Store::alloc | ( | ) |
Allocates a handle to write to and read from.
Definition at line 108 of file store.cpp.
References BLOCK_SIZE, m_cur, m_file, m_front, m_head, m_state, Store::Node::next, portable_fseek(), portable_ftell(), pos(), Store::Node::pos, Reading, STORE_ASSERT, and Writing.
void Store::close | ( | ) |
void Store::dumpBlock | ( | portable_off_t | start, |
portable_off_t | end | ||
) |
Definition at line 400 of file store.cpp.
References m_cur, m_file, and portable_fseek().
void Store::end | ( | ) |
Ends the sequence of writes.
Definition at line 249 of file store.cpp.
References BLOCK_SIZE, m_cur, m_file, m_state, portable_ftell(), Reading, STORE_ASSERT, and Writing.
int Store::open | ( | const char * | name | ) |
Opens the file underlying the store using name as the file name. Returns 0 upon success, or -1 otherwise.
Definition at line 74 of file store.cpp.
References BLOCK_SIZE, Init, m_cur, m_file, m_front, m_head, m_state, portable_fopen(), Reading, and STORE_ASSERT.
|
inline |
|
private |
Definition at line 382 of file store.cpp.
References m_head, Store::Node::next, pos(), and Store::Node::pos.
void Store::printStats | ( | ) |
|
virtual |
Reads size bytes from the store into the array pointed to be buf.
Implements StorageIntf.
Definition at line 319 of file store.cpp.
References BLOCK_POINTER_SIZE, BLOCK_SIZE, m_cur, m_file, m_reads, m_state, portable_fseek(), portable_ftell(), Reading, and STORE_ASSERT.
void Store::release | ( | portable_off_t | handle | ) |
Releases the memory corresponding to the handle returned with alloc()
Definition at line 269 of file store.cpp.
References BLOCK_POINTER_SIZE, BLOCK_SIZE, m_cur, m_file, m_head, m_state, Store::Node::next, portable_fseek(), pos(), Store::Node::pos, Reading, and STORE_ASSERT.
void Store::seek | ( | portable_off_t | handle | ) |
Goes to the start of information corresponding to handle pos
Definition at line 305 of file store.cpp.
References BLOCK_SIZE, m_cur, m_file, m_state, portable_fseek(), pos(), Reading, and STORE_ASSERT.
|
virtual |
Writes size bytes in array buf to the store. First alloc() has to be called.
Implements StorageIntf.
Definition at line 154 of file store.cpp.
References BLOCK_POINTER_SIZE, BLOCK_SIZE, m_cur, m_file, m_front, m_head, m_state, m_writes, Store::Node::next, portable_fseek(), portable_ftell(), pos(), Store::Node::pos, STORE_ASSERT, and Writing.
|
private |
|
private |
|
private |
|
private |
|
private |
Definition at line 119 of file store.h.
Referenced by printStats(), read(), and Store().
|
private |
|
private |
Definition at line 120 of file store.h.
Referenced by printStats(), Store(), and write().