casacore
|
Envelope class for the description of a table column. More...
#include <ColumnDesc.h>
Public Types | |
enum | Option { Direct, Undefined, FixedShape } |
Enumerate the possible column options. More... | |
typedef BaseColumnDesc * | ColumnDescCtor (const String &className) |
Define the type of a XXColumnDesc construction function. More... | |
Public Member Functions | |
ColumnDesc (const BaseColumnDesc &) | |
Construct from a column description. More... | |
ColumnDesc (const ColumnDesc &that) | |
Copy constructor (copy semantics). More... | |
ColumnDesc () | |
Default constructor (needed for ColumnDescSet). More... | |
~ColumnDesc () | |
ColumnDesc & | operator= (const ColumnDesc &that) |
Assignment (copy semantics). More... | |
Bool | operator== (const ColumnDesc &) const |
Comparison. More... | |
Bool | operator!= (const ColumnDesc &) const |
TableRecord & | rwKeywordSet () |
Get access to the set of keywords. More... | |
const TableRecord & | keywordSet () const |
const String & | name () const |
Get the name of the column. More... | |
DataType | dataType () const |
Get the data type of the column. More... | |
DataType | trueDataType () const |
Get the true data type of the column. More... | |
const String & | dataTypeId () const |
Get the type id for non-standard data types (i.e. More... | |
const String & | dataManagerType () const |
Get the type name of the default data manager. More... | |
String & | dataManagerType () |
Get the type name of the default data manager (allowing it to be changed). More... | |
const String & | dataManagerGroup () const |
Get the data manager group. More... | |
String & | dataManagerGroup () |
Get the data manager group. More... | |
void | setDefaultDataManager (Bool always=True) |
If always==True they are always set, otherwise only if empty. More... | |
const String & | comment () const |
Get comment string. More... | |
String & | comment () |
Get comment string (allowing it to be changed). More... | |
int | options () const |
Get the options. More... | |
Bool | isFixedShape () const |
Check if the column is defined with a fixed shape. More... | |
Bool | isScalar () const |
Test if column is a scalar. More... | |
Bool | isArray () const |
Test if column is an array. More... | |
Bool | isTable () const |
Test if column is a table. More... | |
Int | ndim () const |
Get the number of dimensions. More... | |
const IPosition & | shape () const |
Get the predefined shape. More... | |
void | setNdim (uInt ndim) |
Set the number of dimensions. More... | |
void | setShape (const IPosition &shape) |
Set the predefined shape. More... | |
void | setShape (const IPosition &shape, Bool directOption) |
void | setOptions (int options) |
Set the options to the given value. More... | |
uInt | maxLength () const |
Get the maximum value length. More... | |
void | setMaxLength (uInt maxLength) |
Set the maximum value length. More... | |
const TableDesc * | tableDesc () const |
Get table description (in case column contains subtables). More... | |
TableDesc * | tableDesc () |
void | show () const |
Show the column on cout. More... | |
void | show (ostream &os) const |
Show the column. More... | |
void | setName (const String &name) |
Set the name of the column. More... | |
RefColumn * | makeRefColumn (RefTable *rtp, BaseColumn *bcp) const |
Create a RefColumn column object out of this column description. More... | |
ConcatColumn * | makeConcatColumn (ConcatTable *rtp) const |
Create a ConcatColumn column object out of this column description. More... | |
Static Public Member Functions | |
static ColumnDescCtor * | getCtor (const String &name) |
Get a construction function for a XXColumnDesc object (thread-safe). More... | |
static void | registerCtor (const String &name, ColumnDescCtor *func) |
Register a "XXColumnDesc" constructor (thread-safe). More... | |
Protected Attributes | |
BaseColumnDesc * | colPtr_p |
Bool | allocated_p |
Private Member Functions | |
ColumnDesc (BaseColumnDesc *) | |
Construct from a pointer (for class BaseColumn). More... | |
void | checkAdd (const ColumnDescSet &cds) const |
Check if a column can be handled by ColumnDescSet. More... | |
void | checkRename (const ColumnDescSet &cds, const String &newName) const |
Check when a column gets renamed in a table description. More... | |
void | handleAdd (ColumnDescSet &cds) |
Take action after a column has been handled by ColumnDescSet. More... | |
void | handleRename (ColumnDescSet &cds, const String &oldName) |
void | handleRemove (ColumnDescSet &cds) |
void | renameAction (const String &newName, const String &oldName) |
This function allows each column to act upon a rename of another column. More... | |
PlainColumn * | makeColumn (ColumnSet *csp) const |
Create a PlainColumn column object out of this column description. More... | |
void | putFile (AipsIO &ios, const TableAttr &) const |
Store the object in AipsIO. More... | |
void | getFile (AipsIO &, const TableAttr &) |
Get the object from AipsIO. More... | |
Static Private Member Functions | |
static std::map< String, ColumnDescCtor * > & | getRegisterMap () |
Define a map which maps the name of the various XXColumnDesc classes to a static function constructing them. More... | |
static std::map< String, ColumnDescCtor * > | initRegisterMap () |
Register the main data managers. More... | |
Static Private Attributes | |
static std::mutex | theirMutex |
A mutex for additions to the constructor map. More... | |
Friends | |
class | ColumnDescSet |
class | ColumnSet |
class | BaseColumn |
AipsIO & | operator<< (AipsIO &ios, const ColumnDesc &cd) |
Write into AipsIO. More... | |
AipsIO & | operator>> (AipsIO &ios, ColumnDesc &cd) |
Read from AipsIO. More... | |
ostream & | operator<< (ostream &ios, const ColumnDesc &cd) |
Show on ostream. More... | |
Envelope class for the description of a table column.
Public interface
Class ColumnDesc is an envelope for the letter class BaseColDesc and its derivations like ScalarColumnDesc,
ScalarRecordColumnDesc. ArrayColumnDesc, and SubTableDesc. ColumnDesc is meant to examine or slightly modify already existing column descriptions. It allows the retrieval of attributes like name, data type, etc.. For non-const ColumnDesc objects it is possible to modify the attributes comment and keyword set.
Since there are several types of columns, the class ColumnDesc cannot handle all details of those column types. Therefore, to create a column description, an instance of the specialized classes ArrayColumnDesc<T>, etc. has to be constructed. In there column type dependent things like array shape and default value can be defined.
This class also enumerates the possible options which can be used when defining a column via classes like ScalarColumnDesc<T>. These options are:
When getting the description of an arbitrary column, a pointer to that description is needed to allow proper execution of virtual functions. An envelope class is needed to hide this from the user.
Definition at line 132 of file ColumnDesc.h.
typedef BaseColumnDesc* casacore::ColumnDesc::ColumnDescCtor(const String &className) |
Define the type of a XXColumnDesc construction function.
Definition at line 352 of file ColumnDesc.h.
Enumerate the possible column options.
They can be combined by adding (logical or-ing) them.
Enumerator | |
---|---|
Direct |
direct table or array |
Undefined |
undefined values are possible |
FixedShape |
fixed array/table shape |
Definition at line 142 of file ColumnDesc.h.
casacore::ColumnDesc::ColumnDesc | ( | const BaseColumnDesc & | ) |
Construct from a column description.
This constructor is merely for the purpose of the automatic conversion of an object like ScalarColumnDesc<T> to ColumnDesc when adding a column to the table description using the function TableDesc::addColumn.
casacore::ColumnDesc::ColumnDesc | ( | const ColumnDesc & | that | ) |
Copy constructor (copy semantics).
|
inline |
Default constructor (needed for ColumnDescSet).
Definition at line 162 of file ColumnDesc.h.
casacore::ColumnDesc::~ColumnDesc | ( | ) |
|
private |
Construct from a pointer (for class BaseColumn).
|
inlineprivate |
Check if a column can be handled by ColumnDescSet.
It is called before the column gets actually added, etc..
Check if the column can be added to the table description. It is implemented for a virtual column to check if the columns it uses really exist.
Definition at line 386 of file ColumnDesc.h.
References casacore::BaseColumnDesc::checkAdd(), and colPtr_p.
|
inlineprivate |
Check when a column gets renamed in a table description.
It is not used.
Definition at line 390 of file ColumnDesc.h.
References casacore::BaseColumnDesc::checkRename(), and colPtr_p.
|
inline |
Get comment string.
Definition at line 231 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::comment().
|
inline |
Get comment string (allowing it to be changed).
Definition at line 235 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::comment().
|
inline |
Get the data manager group.
Definition at line 218 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::dataManagerGroup().
|
inline |
Get the data manager group.
(allowing it to be changed).
Definition at line 223 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::dataManagerGroup().
|
inline |
Get the type name of the default data manager.
Definition at line 209 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::dataManagerType().
|
inline |
Get the type name of the default data manager (allowing it to be changed).
Definition at line 214 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::dataManagerType().
|
inline |
Get the data type of the column.
This always returns the type of a scalar, even when the column contains arrays.
Definition at line 195 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::dataType().
|
inline |
Get the type id for non-standard data types (i.e.
for TpOther). For standard data types the returned string is empty.
Definition at line 205 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::dataTypeId().
|
static |
Get a construction function for a XXColumnDesc object (thread-safe).
Get the object from AipsIO.
|
staticprivate |
Define a map which maps the name of the various XXColumnDesc classes to a static function constructing them.
This is used when reading a column description back; it in fact determines the exact column type and is an easier thing to do than an enormous switch statement. The map is filled with the main XXColumnDesc construction functions by the function registerColumnDesc upon the first call of ColumnDesc::getFile
.
|
inlineprivate |
Take action after a column has been handled by ColumnDescSet.
It is called after the column has been actually added, etc.. This gives, for instance, the virtual column class the opportunity to update the virtual column list.
Definition at line 399 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::handleAdd().
|
inlineprivate |
Definition at line 403 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::handleRemove().
|
inlineprivate |
Definition at line 401 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::handleRename().
|
staticprivate |
Register the main data managers.
|
inline |
Test if column is an array.
Definition at line 258 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::isArray().
Bool casacore::ColumnDesc::isFixedShape | ( | ) | const |
Check if the column is defined with a fixed shape.
This is always true for scalars. For arrays it is true when the FixedShape flag was set when the column was defined.
|
inline |
Test if column is a scalar.
Definition at line 255 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::isScalar().
|
inline |
Test if column is a table.
Definition at line 261 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::isTable().
|
inline |
Definition at line 184 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::keywordSet().
|
inlineprivate |
Create a PlainColumn column object out of this column description.
Definition at line 414 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::makeColumn().
|
inline |
Create a ConcatColumn column object out of this column description.
Definition at line 347 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::makeConcatColumn().
|
inline |
Create a RefColumn column object out of this column description.
Definition at line 343 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::makeRefColumn().
|
inline |
Get the maximum value length.
Definition at line 304 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::maxLength().
const String& casacore::ColumnDesc::name | ( | ) | const |
Get the name of the column.
|
inline |
Get the number of dimensions.
Definition at line 265 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::ndim().
Bool casacore::ColumnDesc::operator!= | ( | const ColumnDesc & | ) | const |
ColumnDesc& casacore::ColumnDesc::operator= | ( | const ColumnDesc & | that | ) |
Assignment (copy semantics).
Bool casacore::ColumnDesc::operator== | ( | const ColumnDesc & | ) | const |
Comparison.
Two descriptions are equal when their data types, value types (scalar, array or table) and possible dimensionalities are equal.
|
inline |
Get the options.
The possible options are defined by the enum Option. E.g.
Definition at line 246 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::options().
Store the object in AipsIO.
|
static |
Register a "XXColumnDesc" constructor (thread-safe).
|
inlineprivate |
This function allows each column to act upon a rename of another column.
If the old name is used internally, the column can update itself. It is called after handleRename has been called.
Definition at line 410 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::renameAction().
|
inline |
Get access to the set of keywords.
Definition at line 182 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::rwKeywordSet().
If always==True
they are always set, otherwise only if empty.
Definition at line 227 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setDefaultDataManager().
|
inline |
Set the maximum value length.
So far, this is only possible for columns containing String values. An exception is thrown if the column data type is not TpString. Some storage managers support fixed length strings and can store them more efficiently than variable length strings.
Definition at line 312 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setMaxLength().
|
inline |
Set the name of the column.
Definition at line 339 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setName().
|
inline |
Set the number of dimensions.
This is only allowed for arrays. ndim
can be zero to clear the number of dimensions and the shape. Otherwise it can only be used if the dimensionality has not been defined yet.
Definition at line 279 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setNdim().
|
inline |
Set the options to the given value.
Option ColumnDesc::Direct
forces FixedShape
. If FixedShape
is not given (implicitly or explicitly), the column can have no shape, so its shape is cleared.
Definition at line 300 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setOptions().
|
inline |
Set the predefined shape.
This is only allowed for arrays, for which the shape has not been defined yet. If the dimensionality has already been defined, it must match. It will set the option FixedShape
if not set yet.
The first version leaves the Direct
option as is. The second version sets the Direct
option as given.
Definition at line 290 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setShape().
Definition at line 292 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::setShape().
|
inline |
Get the predefined shape.
If not defined, a zero shape will be returned.
Definition at line 270 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::shape().
void casacore::ColumnDesc::show | ( | ) | const |
Show the column on cout.
void casacore::ColumnDesc::show | ( | ostream & | os | ) | const |
Show the column.
|
inline |
Get table description (in case column contains subtables).
Definition at line 317 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::tableDesc().
|
inline |
Definition at line 319 of file ColumnDesc.h.
References colPtr_p, and casacore::BaseColumnDesc::tableDesc().
DataType casacore::ColumnDesc::trueDataType | ( | ) | const |
Get the true data type of the column.
Unlike dataType, it returns an array data type (e.g. TpArrayInt) when the column contains arrays.
|
friend |
Definition at line 136 of file ColumnDesc.h.
|
friend |
Definition at line 134 of file ColumnDesc.h.
|
friend |
Definition at line 135 of file ColumnDesc.h.
|
friend |
Write into AipsIO.
|
friend |
Show on ostream.
|
friend |
Read from AipsIO.
|
protected |
Definition at line 426 of file ColumnDesc.h.
|
protected |
Definition at line 425 of file ColumnDesc.h.
Referenced by checkAdd(), checkRename(), comment(), dataManagerGroup(), dataManagerType(), dataType(), dataTypeId(), handleAdd(), handleRemove(), handleRename(), isArray(), isScalar(), isTable(), keywordSet(), makeColumn(), makeConcatColumn(), makeRefColumn(), maxLength(), ndim(), options(), renameAction(), rwKeywordSet(), setDefaultDataManager(), setMaxLength(), setName(), setNdim(), setOptions(), setShape(), shape(), and tableDesc().
|
staticprivate |
A mutex for additions to the constructor map.
Definition at line 362 of file ColumnDesc.h.