Package uk.ac.starlink.table
Class ConcatStarTable
- java.lang.Object
-
- uk.ac.starlink.table.WrapperStarTable
-
- uk.ac.starlink.table.ConcatStarTable
-
- All Implemented Interfaces:
StarTable
public class ConcatStarTable extends WrapperStarTable
StarTable implementation which concatenates several tables together top-to-bottom. A (possibly blank) metadata table is supplied to define the column and table metadata for the result, and other data tables are added on one way or another, depending which constructor is used. The columns of each data table must be compatible with the columns of the metadata table, or the the data will not be included.- Since:
- 29 Mar 2004
- Author:
- Mark Taylor
-
-
Field Summary
-
Fields inherited from class uk.ac.starlink.table.WrapperStarTable
baseTable
-
-
Constructor Summary
Constructors Constructor Description ConcatStarTable(StarTable meta, java.util.Iterator<StarTable> tableIt)Constructs a concatenated table from a metadata table and an iterator over data-bearing tables.ConcatStarTable(StarTable meta, StarTable[] tables)Constructs a concatenated table from a metadata table and an array of data-bearing tables.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static ColumnInfo[]extendColumnTypes(ColumnInfo[] colInfos, StarTable[] tables)Assembles column metadata objects which are compatible between multiple tables.java.lang.ObjectgetCell(long irow, int icol)Returns the contents of a given table cell.java.lang.Object[]getRow(long irow)Returns the contents of a given table row.longgetRowCount()Returns the number of rows in this table, if known.RowSequencegetRowSequence()Returns an object which can iterate over all the rows in the table sequentially.booleanisRandom()Indicates whether random access is provided by this table.-
Methods inherited from class uk.ac.starlink.table.WrapperStarTable
checkedLongToInt, getBaseTable, getColumnAuxDataInfos, getColumnCount, getColumnInfo, getName, getParameterByName, getParameters, getURL, setName, setParameter, setURL, toString
-
-
-
-
Constructor Detail
-
ConcatStarTable
public ConcatStarTable(StarTable meta, java.util.Iterator<StarTable> tableIt)
Constructs a concatenated table from a metadata table and an iterator over data-bearing tables. If any of the tables supplied by the iterator are incompatible with the metadata inmetaa warning message is issued through the logging system and its rows are ignored.- Parameters:
meta- table supplying column and table metadata for this one; its row count is ignored and its data is never readtableIt- iterator over constituentStarTables which taken in sequence supply the row data for this one
-
ConcatStarTable
public ConcatStarTable(StarTable meta, StarTable[] tables) throws java.io.IOException
Constructs a concatenated table from a metadata table and an array of data-bearing tables. If any oftablesare incompatible with the metadata inmetaan IOException is thrown.- Parameters:
meta- table supplying column and table metadata for this one; its row count is ignored and its data is never readtables- array of tables which taken in sequence supply the row data for this one- Throws:
java.io.IOException- if any oftablesare not compatible withmeta
-
-
Method Detail
-
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
public java.lang.Object getCell(long irow, int icol) throws java.io.IOExceptionDescription 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 by getColumnInfo(icol).getContentClass().- Specified by:
getCellin interfaceStarTable- Overrides:
getCellin classWrapperStarTable- Parameters:
irow- the index of the cell's rowicol- the index of the cell's column- Returns:
- the contents of this cell
- Throws:
java.io.IOException- if there is an error reading the data
-
getRow
public java.lang.Object[] getRow(long irow) throws java.io.IOExceptionDescription 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 by getCell(irow,icol) for all the columns icol in sequence.- Specified by:
getRowin interfaceStarTable- Overrides:
getRowin classWrapperStarTable- Parameters:
irow- the index of the row to retrieve- Returns:
- an array of the objects in each cell in row irow
- Throws:
java.io.IOException- if there is an error reading the data
-
isRandom
public boolean isRandom()
Description copied from interface:StarTableIndicates whether random access is provided by this table. Only if the result is true may theStarTable.getRow(long)andStarTable.getCell(long, int)methods be used.- Specified by:
isRandomin interfaceStarTable- Overrides:
isRandomin classWrapperStarTable- Returns:
- true if table random access methods are available
-
getRowSequence
public RowSequence getRowSequence() throws java.io.IOException
Description copied from interface:StarTableReturns an object which can iterate over all the rows in the table sequentially.- Specified by:
getRowSequencein interfaceStarTable- Overrides:
getRowSequencein classWrapperStarTable- Returns:
- an object providing sequential access to the table data
- Throws:
java.io.IOException- if there is an error providing access
-
extendColumnTypes
public static ColumnInfo[] extendColumnTypes(ColumnInfo[] colInfos, StarTable[] tables) throws java.io.IOException
Assembles column metadata objects which are compatible between multiple tables. Nullability, array shape and element size are set to values which can accommodate all of the input tables. If column count or column data types are inconsistent, an IOException is thrown.This utility method is not used by ConcatStarTable instances, but it may be useful when preparing metadata tables for use with the constructor.
- Parameters:
colInfos- input column metadata objectstables- list of tables with which columns must be compatible- Returns:
- new array of new column metadata objects, based on input list
- Throws:
java.io.IOException- if compatibility cannot be achieved
-
-