Package uk.ac.starlink.votable
Class VOStarTable
- java.lang.Object
-
- uk.ac.starlink.table.AbstractStarTable
-
- uk.ac.starlink.votable.VOStarTable
-
- All Implemented Interfaces:
uk.ac.starlink.table.StarTable
public class VOStarTable extends uk.ac.starlink.table.AbstractStarTableAStarTableimplementation based on a VOTable.Some of the FIELD attributes defined by the VOTable format correspond to standard information in the corresponding ColumnInfo object, and some do not. Those that do are accessed using the relevant ColumnInfo getter/setter methods directly, for instance
String ucd = table.getColumnInfo(0).getUCD();The ones that don't are stored in the ColumnInfo's auxiliary metadata keyed using the various *_INFO public static variables defined in this class. These are accessed using theColumnInfo.getAuxDatum(uk.ac.starlink.table.ValueInfo)method, for instance:String id = (String) table.getColumnInfo(0) .getAuxDatumValue(VOStarTable.ID_INFO);In the same way, if you set an auxiliary metadata item under one of these keys, like this:DescribedValue idVal = new DescribedValue(VOStarTable.ID_INFO, "COL0"); table.getColumnInfo(0).setAuxDatum(idVal);then if the result is written to a VOTable the relevant attribute will be attached to the corresponding FIELD element.- Author:
- Mark Taylor (Starlink)
-
-
Field Summary
Fields Modifier and Type Field Description static uk.ac.starlink.table.ValueInfoCOOSYS_EPOCH_INFOValueInfo for COOSYS epoch attribute.static uk.ac.starlink.table.ValueInfoCOOSYS_EQUINOX_INFOValueInfo for COOSYS equinox attribute.static uk.ac.starlink.table.ValueInfoCOOSYS_SYSTEM_INFOValueInfo for COOSYS system attribute.static uk.ac.starlink.table.ValueInfoDATATYPE_INFOValueInfo for VOTable datatype attribute.static uk.ac.starlink.table.ValueInfoID_INFOValueInfo for VOTable ID attribute.static uk.ac.starlink.table.ValueInfoPRECISION_INFOValueInfo for VOTable precision attribute.static uk.ac.starlink.table.ValueInfoREF_INFOValueInfo for VOTable ref attribute.static uk.ac.starlink.table.ValueInfoTIMESYS_REFPOSITION_INFOValueInfo for TIMESYS refposition attribute.static uk.ac.starlink.table.ValueInfoTIMESYS_TIMEORIGIN_INFOValueInfo for TIMESYS timeorigin attribute.static uk.ac.starlink.table.ValueInfoTIMESYS_TIMESCALE_INFOValueInfo for TIMESYS timescale attribute.static uk.ac.starlink.table.ValueInfoTYPE_INFOValueInfo for VOTable type attribute.static uk.ac.starlink.table.ValueInfoUCD_INFOValueInfo for VOTable ucd attribute.static uk.ac.starlink.table.ValueInfoUTYPE_INFOValueInfo for VOTable utype attribute.static uk.ac.starlink.table.ValueInfoWIDTH_INFOValueInfo for VOTable width attribute.static uk.ac.starlink.table.ValueInfoXTYPE_INFOValueInfo for VOTable xtype attribute.
-
Constructor Summary
Constructors Constructor Description VOStarTable(TableElement votable)Construct a VOStarTable from a TABLE element.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.ObjectgetCell(long lrow, int icol)java.util.List<uk.ac.starlink.table.ValueInfo>getColumnAuxDataInfos()intgetColumnCount()uk.ac.starlink.table.ColumnInfogetColumnInfo(int icol)java.util.List<uk.ac.starlink.table.DescribedValue>getParameters()static intgetRefColumnIndex(java.lang.String colRef, uk.ac.starlink.table.StarTable table)Identifies the column that was labelled with a given ID attribute.java.lang.Object[]getRow(long lrow)longgetRowCount()uk.ac.starlink.table.RowSequencegetRowSequence()static uk.ac.starlink.table.ValueInfogetValueInfo(FieldElement field)Returns a ValueInfo object suitable for holding the values in a VOTable Field (or Param) object.booleanisRandom()
-
-
-
Field Detail
-
ID_INFO
public static final uk.ac.starlink.table.ValueInfo ID_INFO
ValueInfo for VOTable ID attribute.
-
UCD_INFO
public static final uk.ac.starlink.table.ValueInfo UCD_INFO
ValueInfo for VOTable ucd attribute.
-
UTYPE_INFO
public static final uk.ac.starlink.table.ValueInfo UTYPE_INFO
ValueInfo for VOTable utype attribute.
-
XTYPE_INFO
public static final uk.ac.starlink.table.ValueInfo XTYPE_INFO
ValueInfo for VOTable xtype attribute.
-
WIDTH_INFO
public static final uk.ac.starlink.table.ValueInfo WIDTH_INFO
ValueInfo for VOTable width attribute.
-
PRECISION_INFO
public static final uk.ac.starlink.table.ValueInfo PRECISION_INFO
ValueInfo for VOTable precision attribute.
-
REF_INFO
public static final uk.ac.starlink.table.ValueInfo REF_INFO
ValueInfo for VOTable ref attribute.
-
TYPE_INFO
public static final uk.ac.starlink.table.ValueInfo TYPE_INFO
ValueInfo for VOTable type attribute.
-
DATATYPE_INFO
public static final uk.ac.starlink.table.ValueInfo DATATYPE_INFO
ValueInfo for VOTable datatype attribute.
-
COOSYS_SYSTEM_INFO
public static final uk.ac.starlink.table.ValueInfo COOSYS_SYSTEM_INFO
ValueInfo for COOSYS system attribute.
-
COOSYS_EPOCH_INFO
public static final uk.ac.starlink.table.ValueInfo COOSYS_EPOCH_INFO
ValueInfo for COOSYS epoch attribute.
-
COOSYS_EQUINOX_INFO
public static final uk.ac.starlink.table.ValueInfo COOSYS_EQUINOX_INFO
ValueInfo for COOSYS equinox attribute.
-
TIMESYS_TIMEORIGIN_INFO
public static final uk.ac.starlink.table.ValueInfo TIMESYS_TIMEORIGIN_INFO
ValueInfo for TIMESYS timeorigin attribute.
-
TIMESYS_TIMESCALE_INFO
public static final uk.ac.starlink.table.ValueInfo TIMESYS_TIMESCALE_INFO
ValueInfo for TIMESYS timescale attribute.
-
TIMESYS_REFPOSITION_INFO
public static final uk.ac.starlink.table.ValueInfo TIMESYS_REFPOSITION_INFO
ValueInfo for TIMESYS refposition attribute.
-
-
Constructor Detail
-
VOStarTable
public VOStarTable(TableElement votable) throws java.io.IOException
Construct a VOStarTable from a TABLE element. The data itself is inferred or constructed from the state and content of the element.- Parameters:
votable- Table VOElement- Throws:
java.io.IOException
-
-
Method Detail
-
getColumnCount
public int getColumnCount()
- Specified by:
getColumnCountin interfaceuk.ac.starlink.table.StarTable- Specified by:
getColumnCountin classuk.ac.starlink.table.AbstractStarTable
-
getRowCount
public long getRowCount()
- Specified by:
getRowCountin interfaceuk.ac.starlink.table.StarTable- Specified by:
getRowCountin classuk.ac.starlink.table.AbstractStarTable
-
isRandom
public boolean isRandom()
- Specified by:
isRandomin interfaceuk.ac.starlink.table.StarTable- Overrides:
isRandomin classuk.ac.starlink.table.AbstractStarTable
-
getColumnInfo
public uk.ac.starlink.table.ColumnInfo getColumnInfo(int icol)
- Specified by:
getColumnInfoin interfaceuk.ac.starlink.table.StarTable- Specified by:
getColumnInfoin classuk.ac.starlink.table.AbstractStarTable
-
getParameters
public java.util.List<uk.ac.starlink.table.DescribedValue> getParameters()
- Specified by:
getParametersin interfaceuk.ac.starlink.table.StarTable- Overrides:
getParametersin classuk.ac.starlink.table.AbstractStarTable
-
getColumnAuxDataInfos
public java.util.List<uk.ac.starlink.table.ValueInfo> getColumnAuxDataInfos()
- Specified by:
getColumnAuxDataInfosin interfaceuk.ac.starlink.table.StarTable- Overrides:
getColumnAuxDataInfosin classuk.ac.starlink.table.AbstractStarTable
-
getRowSequence
public uk.ac.starlink.table.RowSequence getRowSequence() throws java.io.IOException- Specified by:
getRowSequencein interfaceuk.ac.starlink.table.StarTable- Specified by:
getRowSequencein classuk.ac.starlink.table.AbstractStarTable- Throws:
java.io.IOException
-
getRow
public java.lang.Object[] getRow(long lrow) throws java.io.IOException- Specified by:
getRowin interfaceuk.ac.starlink.table.StarTable- Overrides:
getRowin classuk.ac.starlink.table.AbstractStarTable- Throws:
java.io.IOException
-
getCell
public java.lang.Object getCell(long lrow, int icol) throws java.io.IOException- Specified by:
getCellin interfaceuk.ac.starlink.table.StarTable- Overrides:
getCellin classuk.ac.starlink.table.AbstractStarTable- Throws:
java.io.IOException
-
getValueInfo
public static uk.ac.starlink.table.ValueInfo getValueInfo(FieldElement field)
Returns a ValueInfo object suitable for holding the values in a VOTable Field (or Param) object. The datatype, array shape and other metadata in the returned object are taken from the relevant bits of the supplied field.- Parameters:
field- the FieldElement object for which the ValueInfo is to be constructed- Returns:
- a ValueInfo suitable for field
-
getRefColumnIndex
public static int getRefColumnIndex(java.lang.String colRef, uk.ac.starlink.table.StarTable table)Identifies the column that was labelled with a given ID attribute.- Parameters:
colRef- ID stringtable- table to interrogate; this will presumably be based on a VOStarTable, but it may be some kind of wrapped form of one- Returns:
- index of the column in
tablewhose FIELD element had an ID attribute ofcolRef, or -1 if none exists
-
-