casa  $Rev:20696$
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines
Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
casa::MSMBase Class Reference

Base class for memory-based table storage manager class. More...

#include <MSMBase.h>

Inheritance diagram for casa::MSMBase:
casa::DataManager casa::MemoryStMan

List of all members.

Public Member Functions

 MSMBase ()
 Create a memory storage manager.
 MSMBase (const String &storageManagerName)
 Create a memory storage manager with the given name.
 MSMBase (const String &storageManagerName, const Record &)
 ~MSMBase ()
 
   

DataManagerclone () const
 Clone this object.
String dataManagerType () const
 Get the type name of the data manager (i.e.
String dataManagerName () const
 Get the name given to this storage manager.
uInt nrow () const
 Get the nr of rows in this storage manager.
Bool canAddRow () const
 Does the storage manager allow to add rows? (yes)
Bool canRemoveRow () const
 Does the storage manager allow to delete rows? (yes)
Bool canAddColumn () const
 Does the storage manager allow to add columns? (yes)
Bool canRemoveColumn () const
 Does the storage manager allow to delete columns? (yes)

Static Public Member Functions

static DataManagermakeObject (const String &dataManagerType, const Record &spec)
 Make the object from the string.

Private Member Functions

virtual Bool flush (AipsIO &, Bool fsync)
 Flush and optionally fsync the data.
virtual void create (uInt nrrow)
 Let the storage manager create the nr of rows needed.
virtual void open (uInt nrrow, AipsIO &)
 Open the storage manager file for an existing table.
virtual void prepare ()
 Let the data manager initialize itself further.
virtual void resync (uInt nrrow)
 Resync the storage manager with the new file contents.
virtual void deleteManager ()
 The data manager will be deleted (because all its columns are requested to be deleted).
void addRow (uInt nrrow)
 Add rows to all columns.
void removeRow (uInt rownr)
 Delete a row from all columns.
DataManagerColumnmakeScalarColumn (const String &name, int dataType, const String &dataTypeID)
 Create a column in the storage manager on behalf of a table column.
DataManagerColumnmakeDirArrColumn (const String &name, int dataType, const String &dataTypeID)
 Create a direct array column.
DataManagerColumnmakeIndArrColumn (const String &name, int dataType, const String &dataTypeID)
 Create an indirect array column.
Bool canReallocateColumns () const
 The MemoryStMan wants to do reallocateColumn.
DataManagerColumnreallocateColumn (DataManagerColumn *column)
 Reallocate the column object if it is part of this data manager.
void addColumn (DataManagerColumn *)
 Add a column.
void removeColumn (DataManagerColumn *)
 Delete a column.

Private Attributes

String stmanName_p
 Name given by user to this storage manager.
uInt nrrow_p
 The number of rows in the columns.
uInt nrrowCreate_p
 The number of rows in create().
PtrBlock< MSMColumn * > colSet_p
 The assembly of all columns.

Detailed Description

Base class for memory-based table storage manager class.

Intended use:

Internal

Review Status

Reviewed By:
UNKNOWN
Date Reviewed:
before2004/08/25

Prerequisite

Etymology

MSMBase is the base class for MemoryStMan.

Synopsis

See class MemoryStMan for the description.

Definition at line 66 of file MSMBase.h.


Constructor & Destructor Documentation

Create a memory storage manager.

Its name will be blank.

casa::MSMBase::MSMBase ( const String storageManagerName)

Create a memory storage manager with the given name.

Its name can be used later in e.g. Table::addColumn to add a column to this storage manager.
Note that the 2nd constructor is needed for table creation from a record specification.

casa::MSMBase::MSMBase ( const String storageManagerName,
const Record  
)

   


Member Function Documentation

void casa::MSMBase::addColumn ( DataManagerColumn ) [private, virtual]

Add a column.

Reimplemented from casa::DataManager.

void casa::MSMBase::addRow ( uInt  nrrow) [private, virtual]

Add rows to all columns.

Reimplemented from casa::DataManager.

Bool casa::MSMBase::canAddColumn ( ) const [virtual]

Does the storage manager allow to add columns? (yes)

Reimplemented from casa::DataManager.

Bool casa::MSMBase::canAddRow ( ) const [virtual]

Does the storage manager allow to add rows? (yes)

Reimplemented from casa::DataManager.

Bool casa::MSMBase::canReallocateColumns ( ) const [private, virtual]

The MemoryStMan wants to do reallocateColumn.

Reimplemented from casa::DataManager.

Bool casa::MSMBase::canRemoveColumn ( ) const [virtual]

Does the storage manager allow to delete columns? (yes)

Reimplemented from casa::DataManager.

Bool casa::MSMBase::canRemoveRow ( ) const [virtual]

Does the storage manager allow to delete rows? (yes)

Reimplemented from casa::DataManager.

DataManager* casa::MSMBase::clone ( ) const [virtual]

Clone this object.

It does not clone MSMColumn objects possibly used.

Implements casa::DataManager.

virtual void casa::MSMBase::create ( uInt  nrrow) [private, virtual]

Let the storage manager create the nr of rows needed.

Implements casa::DataManager.

Get the name given to this storage manager.

Reimplemented from casa::DataManager.

Get the type name of the data manager (i.e.

MemoryStMan).

Implements casa::DataManager.

virtual void casa::MSMBase::deleteManager ( ) [private, virtual]

The data manager will be deleted (because all its columns are requested to be deleted).

It does not have to do anything.

Implements casa::DataManager.

virtual Bool casa::MSMBase::flush ( AipsIO ,
Bool  fsync 
) [private, virtual]

Flush and optionally fsync the data.

It does not done anything and always returns a False status.

Implements casa::DataManager.

DataManagerColumn* casa::MSMBase::makeDirArrColumn ( const String name,
int  dataType,
const String dataTypeID 
) [private, virtual]

Create a direct array column.

Implements casa::DataManager.

DataManagerColumn* casa::MSMBase::makeIndArrColumn ( const String name,
int  dataType,
const String dataTypeID 
) [private, virtual]

Create an indirect array column.

Implements casa::DataManager.

static DataManager* casa::MSMBase::makeObject ( const String dataManagerType,
const Record spec 
) [static]

Make the object from the string.

This function gets registered in the DataManager "constructor" map.

DataManagerColumn* casa::MSMBase::makeScalarColumn ( const String name,
int  dataType,
const String dataTypeID 
) [private, virtual]

Create a column in the storage manager on behalf of a table column.

Create a scalar column.

Implements casa::DataManager.

uInt casa::MSMBase::nrow ( ) const [inline]

Get the nr of rows in this storage manager.

Definition at line 97 of file MSMBase.h.

References nrrow_p.

virtual void casa::MSMBase::open ( uInt  nrrow,
AipsIO  
) [private, virtual]

Open the storage manager file for an existing table.

It fills the rows with 0 values.

Implements casa::DataManager.

virtual void casa::MSMBase::prepare ( ) [private, virtual]

Let the data manager initialize itself further.

It creates nr of rows (given to create) if needed. Note this is done after reallocateColumn.

Reimplemented from casa::DataManager.

Reallocate the column object if it is part of this data manager.

It returns a pointer to the new column object. It is used to replace an MSMIndColumn object for indirect array with a fixed shape by an MSMDirColumn object.

Reimplemented from casa::DataManager.

void casa::MSMBase::removeColumn ( DataManagerColumn ) [private, virtual]

Delete a column.

Reimplemented from casa::DataManager.

void casa::MSMBase::removeRow ( uInt  rownr) [private, virtual]

Delete a row from all columns.

Reimplemented from casa::DataManager.

virtual void casa::MSMBase::resync ( uInt  nrrow) [private, virtual]

Resync the storage manager with the new file contents.

It adds or removes rows as needed. It cannot know which rows are deleted, so it always deletes the last rows.

Implements casa::DataManager.


Member Data Documentation

The assembly of all columns.

Definition at line 188 of file MSMBase.h.

The number of rows in the columns.

Definition at line 184 of file MSMBase.h.

Referenced by nrow().

The number of rows in create().

Definition at line 186 of file MSMBase.h.

Name given by user to this storage manager.

Definition at line 182 of file MSMBase.h.


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