Class EmptyStarTable
java.lang.Object
uk.ac.starlink.table.WrapperStarTable
uk.ac.starlink.table.EmptyStarTable
- All Implemented Interfaces:
Closeable, AutoCloseable, StarTable
A wrapper table which has the same metadata as its base table, but no rows.
- Since:
- 5 Aug 2004
- Author:
- Mark Taylor (Starlink)
-
Field Summary
Fields inherited from class WrapperStarTable
baseTable -
Constructor Summary
ConstructorsConstructorDescriptionCreates a new empty table with no columns, no rows and no parameters.EmptyStarTable(StarTable baseTable) Creates a new empty table with metadata taken from an existing one. -
Method Summary
Modifier and TypeMethodDescriptiongetCell(long lrow, int icol) Returns the contents of a given table cell.Object[]getRow(long lrow) Returns the contents of a given table row.Returns an object which can provide random access to this table's data, if random access is implemented.longReturns the number of rows in this table, if known.Returns an object which can iterate over all the rows in the table sequentially.Returns an object which can iterate over all the rows in the table, but which may also be requested to split recursively for potentially parallel processing.booleanisRandom()Indicates whether random access is provided by this table.Methods inherited from class WrapperStarTable
checkedLongToInt, close, getBaseTable, getColumnAuxDataInfos, getColumnCount, getColumnInfo, getName, getParameterByName, getParameters, getURL, setName, setParameter, setURL, toString
-
Constructor Details
-
EmptyStarTable
Creates a new empty table with metadata taken from an existing one.- Parameters:
baseTable- base table
-
EmptyStarTable
public EmptyStarTable()Creates a new empty table with no columns, no rows and no parameters.
-
-
Method Details
-
isRandom
public boolean isRandom()Description copied from interface:StarTableIndicates whether random access is provided by this table. Only if the result istruemay theStarTable.getRowAccess(),StarTable.getRow(long)andStarTable.getCell(long, int)methods be used.- Specified by:
isRandomin interfaceStarTable- Overrides:
isRandomin classWrapperStarTable- Returns:
trueif table random access methods are available
-
getRowCount
public long getRowCount()Description copied from interface:StarTableReturns the number of rows in this table, if known. If the number of rows cannot be (easily) determined, a value of -1 will be returned.- Specified by:
getRowCountin interfaceStarTable- Overrides:
getRowCountin classWrapperStarTable- Returns:
- the number of rows, or -1
-
getCell
Description copied from interface:StarTableReturns the contents of a given table cell. The class of the returned object should be the same as, or a subclass of, the class returned bygetColumnInfo(icol).getContentClass().This method is safe for concurrent use from multiple threads, but in general it is recommended to use a
RowAccessinstead.- Specified by:
getCellin interfaceStarTable- Overrides:
getCellin classWrapperStarTable- Parameters:
lrow- the index of the cell's rowicol- the index of the cell's column- Returns:
- the contents of this cell
-
getRow
Description copied from interface:StarTableReturns the contents of a given table row. The returned value is equivalent to an array formed of all the objects returned bygetCell(irow,icol)for all the columnsicolin sequence.This method is safe for concurrent use from multiple threads, but in general it is recommended to use a
RowAccessinstead.- Specified by:
getRowin interfaceStarTable- Overrides:
getRowin classWrapperStarTable- Parameters:
lrow- the index of the row to retrieve- Returns:
- an array of the objects in each cell in row
irow
-
getRowSequence
Description copied from interface:StarTableReturns an object which can iterate over all the rows in the table sequentially. Each such returned object is safe for use within a single thread, but not in general from multiple threads concurrently.- Specified by:
getRowSequencein interfaceStarTable- Overrides:
getRowSequencein classWrapperStarTable- Returns:
- new RowSequence
-
getRowAccess
Description copied from interface:StarTableReturns an object which can provide random access to this table's data, if random access is implemented. Each such returned object is safe for use within a single thread, but not in general from multiple threads concurrently.- Specified by:
getRowAccessin interfaceStarTable- Overrides:
getRowAccessin classWrapperStarTable- Returns:
- new RowAccess
-
getRowSplittable
Description copied from interface:StarTableReturns an object which can iterate over all the rows in the table, but which may also be requested to split recursively for potentially parallel processing.The return value must be non-null, and may provide splitting arrangements specially appropriate for the implementation. If this table 'wraps' an upstream table, it is usually best to base the implementation on calls to the the upstream
getRowSplittablemethod, so that upstream policy about how to divide up the table is respected. However, implementations without special requirements may returnTables.getDefaultRowSplittable(this).- Specified by:
getRowSplittablein interfaceStarTable- Overrides:
getRowSplittablein classWrapperStarTable- Returns:
- new RowSplittable
- See Also:
-