SubTabDesc.h

Classes

SubTableDesc -- Description of columns containing tables (full description)

class SubTableDesc : public BaseColumnDesc

Interface

Public Members
SubTableDesc (const String& columnName, const String& comment, const String& tableDescName, int options = 0)
SubTableDesc (const String& columnName, const String& comment, const TableDesc&, int options = 0)
SubTableDesc (const String& columnName, const String& comment, TableDesc*, int options = 0)
SubTableDesc (const SubTableDesc&)
~SubTableDesc()
SubTableDesc& operator= (const SubTableDesc&)
BaseColumnDesc* clone() const
TableDesc* tableDesc()
String className() const
PlainColumn* makeColumn (ColumnSet*) const
void show (ostream& os) const
Protected Members
SubTableDesc (SimpleOrderedMap<String, BaseColumnDesc* (*)(const String&)>&)
static BaseColumnDesc* makeDesc(const String& name)
virtual void putDesc (AipsIO&) const
virtual void getDesc (AipsIO&)
Private Members
Bool readTableDesc()
void handleAdd (ColumnDescSet&)

Description

Review Status

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

Prerequisite

Etymology

SubTableDesc holds a description of a subtable contained in the columns of the parent table.

Synopsis

SubTableDesc describes a table column containing subtables. The semantics of subtables are described below. The column description is constructed using a table description describing the subtable. This subtable decription or its name is stored with the column description. When a table containing this column gets created, the subtable description gets copied and this copy is thereafter frozen.

Constructing a column description for a subtable can be done in 3 ways:

A column can be direct or indirect. Direct columns will be written directly in the table file. All cells in the column must have the same description and it is therefore not possible to change a description. The subtables in indirect columns will be stored in separate files. The cells in indirect columns can contain different tables.

Example

     // First build the new description of a subtable.
     // Define keyword subkey (integer) having value 10.
     // Define columns ra and dec (double).
     TableDesc subTableDesc("tTableDesc_sub", "1", TableDesc::New);
     subTableDesc.keywordSet().keysInt()("subkey") = 10;
     subTableDesc.addColumn (TpDouble, "ra");
     subTableDesc.addColumn (TpDouble, "dec");

     // Now create a new table description
     TableDesc td("tTableDesc", "1", TableDesc::New);

     // Add columns containing subtables.
     // This is done in 3 slighty different ways, which all have
     // their own (dis)advantages.
     // This is described in detail at the SubTableDesc constructors.
     td.addColumn (SubTableDesc("sub1", "subtable by name","tTableDesc_sub"));
     td.addColumn (SubTableDesc("sub2", "subtable copy",    subTableDesc));
     td.addColumn (SubTableDesc("sub3", "subtable pointer", &subTableDesc));

Motivation

Several column description classes are needed to allow the user to define attributes which are special for each column type. For columns containing a table this is the table description.

To Do

Member Description

SubTableDesc (const String& columnName, const String& comment, const String& tableDescName, int options = 0)

Construct from a table description with the given name. The description does not need to exist yet. Only when the table gets created, the description will be read and must exist. This means that the table description is not frozen; the most recent description will be used when creating the column.

SubTableDesc (const String& columnName, const String& comment, const TableDesc&, int options = 0)

Construct from the given table description, which will be copied and frozen.

SubTableDesc (const String& columnName, const String& comment, TableDesc*, int options = 0)

Construct from the given table description, which will be used directly. The description gets frozen when the column is written. Care should be taken, because the given table description must not be deleted before the column description gets destructed.

SubTableDesc (const SubTableDesc&)

Copy constructor (copy semantics).

~SubTableDesc()

SubTableDesc& operator= (const SubTableDesc&)

Assignment (copy semantics).

BaseColumnDesc* clone() const

Clone this column description to another.

TableDesc* tableDesc()

Get the table description.

Thrown Exceptions

String className() const

Get the name of this class.

PlainColumn* makeColumn (ColumnSet*) const

Create a Column column object out of this. This is used by class ColumnSet to construct a table column object.

void show (ostream& os) const

Show the column.

SubTableDesc (SimpleOrderedMap<String, BaseColumnDesc* (*)(const String&)>&)

Construct the object to register its class.

static BaseColumnDesc* makeDesc(const String& name)

Create the object from AipsIO (this function is registered).

virtual void putDesc (AipsIO&) const

Put the object.

virtual void getDesc (AipsIO&)

Get the object.

Bool readTableDesc()

Read table description (if passed by name). If the table description is not found, a False value is returned.

Thrown Exceptions

void handleAdd (ColumnDescSet&)

Handle the addition of the subtable description (clear the flag).