Package uk.ac.starlink.table
Class ExplodedStarTable
- java.lang.Object
-
- uk.ac.starlink.table.WrapperStarTable
-
- uk.ac.starlink.table.ExplodedStarTable
-
- All Implemented Interfaces:
java.io.Closeable,java.lang.AutoCloseable,StarTable
public class ExplodedStarTable extends WrapperStarTable
Wrapper table which takes any column whose value is N-element arrays and turns it into N scalar-valued columns.- Since:
- 2 Mar 2005
- Author:
- Mark Taylor (Starlink)
-
-
Field Summary
-
Fields inherited from class uk.ac.starlink.table.WrapperStarTable
baseTable
-
-
Constructor Summary
Constructors Constructor Description ExplodedStarTable(StarTable baseTable)Constructs a table in which all fixed-length array-valued columns are exploded.ExplodedStarTable(StarTable baseTable, boolean[] colFlags)Constructs a table in which specified columns are exploded.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.ObjectgetCell(long irow, int icol)Returns the contents of a given table cell.intgetColumnCount()Returns the number of columns in this table.ColumnInfogetColumnInfo(int icol)Returns the object describing the data in a given column.java.lang.Object[]getRow(long irow)Returns the contents of a given table row.RowAccessgetRowAccess()Returns an object which can provide random access to this table's data, if random access is implemented.RowSequencegetRowSequence()Returns an object which can iterate over all the rows in the table sequentially.RowSplittablegetRowSplittable()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.-
Methods inherited from class uk.ac.starlink.table.WrapperStarTable
checkedLongToInt, close, getBaseTable, getColumnAuxDataInfos, getName, getParameterByName, getParameters, getRowCount, getURL, isRandom, setName, setParameter, setURL, toString
-
-
-
-
Constructor Detail
-
ExplodedStarTable
public ExplodedStarTable(StarTable baseTable, boolean[] colFlags)
Constructs a table in which specified columns are exploded. All of the specified columns must have values which are fixed-length arrays.- Parameters:
baseTable- base tablecolFlags- array of flags the same length as the number of columns inbaseTable; true elements indicate columns in the base table which should be exploded- Throws:
java.lang.IllegalArgumentException- if any column specified bycolFlagshas a type which is not a fixed-length array
-
ExplodedStarTable
public ExplodedStarTable(StarTable baseTable)
Constructs a table in which all fixed-length array-valued columns are exploded.- Parameters:
baseTable- base table
-
-
Method Detail
-
getColumnCount
public int getColumnCount()
Description copied from interface:StarTableReturns the number of columns in this table.- Specified by:
getColumnCountin interfaceStarTable- Overrides:
getColumnCountin classWrapperStarTable- Returns:
- the number of columns
-
getColumnInfo
public ColumnInfo getColumnInfo(int icol)
Description copied from interface:StarTableReturns the object describing the data in a given column.- Specified by:
getColumnInfoin interfaceStarTable- Overrides:
getColumnInfoin classWrapperStarTable- Parameters:
icol- the column for which header information is required- Returns:
- a ValueInfo object for column icol
-
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().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:
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.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:
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
-
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. 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
- Throws:
java.io.IOException- if there is an error providing access
-
getRowAccess
public RowAccess getRowAccess() throws java.io.IOException
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
- Throws:
java.io.IOException- if there is an error setting up access
-
getRowSplittable
public RowSplittable getRowSplittable() throws java.io.IOException
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
- Throws:
java.io.IOException- See Also:
RowRunner
-
-