casacore
Public Member Functions | Private Member Functions | Private Attributes | List of all members
casacore::TableIndexProxy Class Reference

More...

#include <TableIndexProxy.h>

Public Member Functions

 TableIndexProxy (const TableProxy &table, const Vector< String > &columnNames, Bool noSort)
 Construct for the given columns in the table. More...
 
 TableIndexProxy (const TableIndexProxy &)
 Copy constructor. More...
 
 ~TableIndexProxy ()
 
Bool isUnique () const
 Are all keys in the index unique? More...
 
Vector< StringcolumnNames () const
 Return the names of the columns forming the index. More...
 
void setChanged (const Vector< String > &columnNames)
 Something has changed in the table, so the index has to be recreated. More...
 
Int64 getRowNumber (const Record &key)
 Find the row number matching the key. More...
 
Vector< Int64getRowNumbers (const Record &key)
 Find the row numbers matching the key. More...
 
Vector< Int64getRowNumbersRange (const Record &lower, const Record &upper, Bool lowerInclusive, Bool upperInclusive)
 Find the row numbers matching the key range. More...
 

Private Member Functions

TableIndexProxyoperator= (const TableIndexProxy &)
 Assignment is forbidden. More...
 

Private Attributes

ColumnsIndexscaIndex_p
 
ColumnsIndexArrayarrIndex_p
 

Detailed Description

Proxy for table index access.

Intended use:

Public interface

Review Status

Reviewed By:
Paul Shannon
Date Reviewed:
1995/09/15
Test programs:
tgtable.g

Prerequisite

Synopsis

TableIndexProxy gives access to indexed access to tables, both for scalar columns and array columns. It is primarily meant to be used in classes that wrap access to it from scripting languages (like Glish and Python). However, it can also be used directly from other C++ code.

A TableIndexProxy object is usually created by class TableProxy.

Definition at line 70 of file TableIndexProxy.h.

Constructor & Destructor Documentation

◆ TableIndexProxy() [1/2]

casacore::TableIndexProxy::TableIndexProxy ( const TableProxy table,
const Vector< String > &  columnNames,
Bool  noSort 
)

Construct for the given columns in the table.

◆ TableIndexProxy() [2/2]

casacore::TableIndexProxy::TableIndexProxy ( const TableIndexProxy )

Copy constructor.

◆ ~TableIndexProxy()

casacore::TableIndexProxy::~TableIndexProxy ( )

Member Function Documentation

◆ columnNames()

Vector<String> casacore::TableIndexProxy::columnNames ( ) const

Return the names of the columns forming the index.

◆ getRowNumber()

Int64 casacore::TableIndexProxy::getRowNumber ( const Record key)

Find the row number matching the key.

All keys have to be unique, otherwise an exception is thrown. If no match is found, -1 is returned.

◆ getRowNumbers()

Vector<Int64> casacore::TableIndexProxy::getRowNumbers ( const Record key)

Find the row numbers matching the key.

It should be used instead of getRowNumber if the same key can exist multiple times.

◆ getRowNumbersRange()

Vector<Int64> casacore::TableIndexProxy::getRowNumbersRange ( const Record lower,
const Record upper,
Bool  lowerInclusive,
Bool  upperInclusive 
)

Find the row numbers matching the key range.

The boolean arguments tell if the lower and upper key are part of the range.

◆ isUnique()

Bool casacore::TableIndexProxy::isUnique ( ) const

Are all keys in the index unique?

◆ operator=()

TableIndexProxy& casacore::TableIndexProxy::operator= ( const TableIndexProxy )
private

Assignment is forbidden.

◆ setChanged()

void casacore::TableIndexProxy::setChanged ( const Vector< String > &  columnNames)

Something has changed in the table, so the index has to be recreated.

An empty vector means that all columns have changed, otherwise only the given columns.

Member Data Documentation

◆ arrIndex_p

ColumnsIndexArray* casacore::TableIndexProxy::arrIndex_p
private

Definition at line 113 of file TableIndexProxy.h.

◆ scaIndex_p

ColumnsIndex* casacore::TableIndexProxy::scaIndex_p
private

Definition at line 112 of file TableIndexProxy.h.


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