DataDescription.java

package nom.tam.fits.header;

/*
 * #%L
 * nom.tam FITS library
 * %%
 * Copyright (C) 1996 - 2021 nom-tam-fits
 * %%
 * This is free and unencumbered software released into the public domain.
 * 
 * Anyone is free to copy, modify, publish, use, compile, sell, or
 * distribute this software, either in source code form or as a compiled
 * binary, for any purpose, commercial or non-commercial, and by any
 * means.
 * 
 * In jurisdictions that recognize copyright laws, the author or authors
 * of this software dedicate any and all copyright interest in the
 * software to the public domain. We make this dedication for the benefit
 * of the public at large and to the detriment of our heirs and
 * successors. We intend this dedication to be an overt act of
 * relinquishment in perpetuity of all present and future rights to this
 * software under copyright law.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 * #L%
 */

/**
 * This data dictionary contains FITS keywords that have been widely used within
 * the astronomical community. It is recommended that these keywords only be
 * used as defined here. These are the keywords that describe the data or the
 * FITS file itself
 * 
 * <pre>
 * @see <a href="http://heasarc.gsfc.nasa.gov/docs/fcg/common_dict.html">http://heasarc.gsfc.nasa.gov/docs/fcg/common_dict.html</a>
 * </pre>
 * 
 * @author Richard van Nieuwenhoven
 */
public enum DataDescription implements IFitsHeader {
    /**
     * The value field shall contain a character string that uniquely defines
     * the configuration state, or version, of the the software processing
     * system that generated the data contained in the HDU. This keyword differs
     * from the CREATOR keyword in that it give the name and version of the
     * overall processing system and not just the name and version of a single
     * program.
     */
    CONFIGUR(SOURCE.INTEGRAL, HDU.ANY, VALUE.STRING, "software configuration used to process the data"),
    /**
     * The value field shall contain a character string giving the name, and
     * optionally, the version of the program that originally created the
     * current FITS HDU. This keyword is synonymous with the PROGRAM keyword.
     * Example: 'TASKNAME V1.2.3'
     */
    CREATOR(SOURCE.HEASARC, HDU.ANY, VALUE.STRING, "the name of the software task that created the file"),

    /**
     * The value field shall contain a character string giving the the host file
     * name used to record the original data.
     */
    FILENAME(SOURCE.NOAO, HDU.ANY, VALUE.STRING, "name of the file "),

    /**
     * The value field shall contain a character string giving the file type
     * suffix of the host file name. The full file name typically consists of
     * the root name (see ROOTNAME) followed by a file type suffix, separated by
     * the period ('.') character.
     */
    FILETYPE(SOURCE.UNKNOWN, HDU.ANY, VALUE.STRING, "type of file"),

    /**
     * The value fields of this hierarchical set of indexed keywords shall
     * contain character strings that classify the type of data contained in the
     * HDU. The HDUCLAS1 keyword gives the highest, most general data
     * classification, and the HDUCLAS2 and higher keywords provide
     * progressively more detailed subclassifications of the data.
     */
    HDUCLASn(SOURCE.HEASARC, HDU.ANY, VALUE.STRING, "hierarchical classification of the data"),

    /**
     * The value field shall contain a character string that identifies the
     * domain to which the associated HDUCLASn keywords apply. This keyword
     * typically identifies the institution or project that has defined the
     * allowed set of values for the associated hierarchical HDUCLASn keywords.
     */
    HDUCLASS(SOURCE.HEASARC, HDU.ANY, VALUE.STRING, "general identifier for the classification of the data"),

    /**
     * The value field shall contain a character string that gives a reference
     * to a document that describes the allowed values that may be assigned to
     * the HDUCLASn data classification keywords.
     */
    HDUDOC(SOURCE.HEASARC, HDU.ANY, VALUE.STRING, "reference to document describing the data format"),

    /**
     * This keyword is synonymous to the standard EXTLEVEL keyword except that
     * it may also be used in the primary key. It is recommended that the
     * HDULEVEL and EXTLEVEL keywords should not both be given in the same HDU
     * key, but if they are, then the HDULEVEL keyword will have precedence.
     */
    HDULEVEL(SOURCE.UNKNOWN, HDU.ANY, VALUE.INTEGER, "hierarchical level of the HDU"),
    /**
     * This keyword is synonymous to the standard EXTNAME keyword except that it
     * may also be used in the primary key. It is recommended that the HDUNAME
     * and EXTNAME keywords should not both be given in the same HDU key, but if
     * they are, then the HDUNAME keyword will have precedence.
     */
    HDUNAME(SOURCE.UNKNOWN, HDU.ANY, VALUE.STRING, "descriptive name of the HDU"),

    /**
     * This keyword is synonymous to the standard EXTVER keyword except that it
     * may also be used in the primary key. It is recommended that the HDUVER
     * and EXTVER keywords should not both be given in the same HDU key, but if
     * they are, then the HDUVER keyword will have precedence.
     */
    HDUVER(SOURCE.UNKNOWN, HDU.ANY, VALUE.INTEGER, "version number of the HDU"),
    /**
     * The value field shall contain a character string that gives the specific
     * version of the document referenced by HDUDOC.
     */
    HDUVERS(SOURCE.HEASARC, HDU.ANY, VALUE.STRING, "specific version of the document referenced by HDUDOC"),
    /**
     * The value field shall contain an integer giving the number of standard
     * extensions contained in the FITS file. This keyword may only be used in
     * the primary array key.
     */
    NEXTEND(SOURCE.STScI, HDU.PRIMARY, VALUE.INTEGER, "Number of standard extensions"),
    /**
     * The value field shall contain a character string giving the name, and
     * optionally, the version of the program that originally created the
     * current FITS HDU. This keyword is synonymous with the CREATOR keyword.
     * Example: 'TASKNAME V1.2.3'
     */
    PROGRAM(SOURCE.UCOLICK, HDU.ANY, VALUE.STRING, "the name of the software task that created the file"),
    /**
     * The value field shall contain a character string giving the root of the
     * host file name. The full file name typically consists of the root name
     * followed by a file type suffix (see FILETYPE), separated by the period
     * ('.') character.
     */
    ROOTNAME(SOURCE.UNKNOWN, HDU.ANY, VALUE.STRING, "rootname of the file"),
    /**
     * The value field of this indexed keyword shall contain a floating point
     * number specifying the suggested bin size when producing a histogram of
     * the values in column n. This keyword is typically used in conjunction the
     * TLMINn and TLMAXn keywords when constructing a histogram of the values in
     * column n, such that the histogram ranges from TLMINn to TLMAXn with the
     * histogram bin size given by TDBINn. This keyword may only be used in
     * 'TABLE' or 'BINTABLE' extensions.
     */
    TDBINn(SOURCE.CXC, HDU.TABLE, VALUE.REAL, "default histogram bin size for the column"),
    /**
     * The value field of this indexed keyword shall contain a floating point
     * number specifying the maximum valid physical value represented in column
     * n of the table, exclusive of any special values. This keyword may only be
     * used in 'TABLE' or 'BINTABLE' extensions and is analogous to the DATAMAX
     * keyword used for FITS images.
     */
    TDMAXn(SOURCE.HEASARC, HDU.TABLE, VALUE.REAL, "maximum value in the column"),
    /**
     * The value field of this indexed keyword shall contain a floating point
     * number specifying the minimum valid physical value represented in column
     * n of the table, exclusive of any special values. This keyword may only be
     * used in 'TABLE' or 'BINTABLE' extensions and is analogous to the DATAMIN
     * keyword used for FITS images.
     */
    TDMINn(SOURCE.HEASARC, HDU.TABLE, VALUE.REAL, "minimum value in the column"),
    /**
     * The value field shall contain a character string giving a title that is
     * suitable for display purposes, e.g., for annotation on images or plots of
     * the data contained in the HDU.
     */
    TITLE(SOURCE.ROSAT, HDU.ANY, VALUE.STRING, "title for the observation or data"),
    /**
     * The value field of this indexed keyword shall contain a floating point
     * number specifying the upper bound of the legal range of physical values
     * that may be represented in column n of the table. The column may contain
     * values that are greater than this legal maximum value but the
     * interpretation of such values is not defined here. The value of this
     * keyword is typically used as the maxinum value when constructing a
     * histogram of the values in the column. This keyword may only be used in
     * 'TABLE' or 'BINTABLE' extensions.
     */
    TLMAXn(SOURCE.HEASARC, HDU.TABLE, VALUE.REAL, "maximum legal value in the column"),
    /**
     * The value field of this indexed keyword shall contain a floating point
     * number specifying the lower bound of the legal range of physical values
     * that may be represented in column n of the table. The column may contain
     * values that are less than this legal minimum value but the interpretation
     * of such values is not defined here. The value of this keyword is
     * typically used as the mininum value when constructing a histogram of the
     * values in the column. This keyword may only be used in 'TABLE' or
     * 'BINTABLE' extensions.
     */
    TLMINn(SOURCE.HEASARC, HDU.TABLE, VALUE.REAL, "minimum legal value in the column"),
    /**
     * The value field shall contain a character string that defines the order
     * in which the rows in the current FITS ASCII or binary table extension
     * have been sorted. The character string lists the name (as given by the
     * TTYPEn keyword) of the primary sort column, optionally followed by the
     * names of any secondary sort column(s). The presence of this keyword
     * indicates that the rows in the table have been sorted first by the values
     * in the primary sort column; any rows that have the same value in the
     * primary column have been further sorted by the values in the secondary
     * sort column and so on for all the specified columns. If more than one
     * column is specified by TSORTKEY then the names must be separated by a
     * comma. One or more spaces are also allowed between the comma and the
     * following column name. By default, columns are sorted in ascending order,
     * but a minus sign may precede the column name to indicate that the rows
     * are sorted in descending order. This keyword may only be used in 'TABLE'
     * or 'BINTABLE' extensions. Example: TSORTKEY = 'TIME, RA, DEC'.
     */
    TSORTKEY(SOURCE.HEASARC, HDU.TABLE, VALUE.STRING, "defines the sort order of a table");

    @SuppressWarnings("CPD-START")
    private final IFitsHeader key;

    DataDescription(IFitsHeader.SOURCE status, HDU hdu, VALUE valueType, String comment) {
        this.key = new FitsHeaderImpl(name(), status, hdu, valueType, comment);
    }

    @Override
    public String comment() {
        return this.key.comment();
    }

    @Override
    public HDU hdu() {
        return this.key.hdu();
    }

    @Override
    public String key() {
        return this.key.key();
    }

    @Override
    public IFitsHeader n(int... number) {
        return this.key.n(number);
    }

    @Override
    public SOURCE status() {
        return this.key.status();
    }

    @Override
    @SuppressWarnings("CPD-END")
    public VALUE valueType() {
        return this.key.valueType();
    }
}