1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * FITS image format common prototypes and structures
3cabdff1aSopenharmony_ci * Copyright (c) 2017 Paras Chadha
4cabdff1aSopenharmony_ci *
5cabdff1aSopenharmony_ci * This file is part of FFmpeg.
6cabdff1aSopenharmony_ci *
7cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
8cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
9cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
10cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
11cabdff1aSopenharmony_ci *
12cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
13cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
14cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15cabdff1aSopenharmony_ci * Lesser General Public License for more details.
16cabdff1aSopenharmony_ci *
17cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
18cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
19cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20cabdff1aSopenharmony_ci */
21cabdff1aSopenharmony_ci
22cabdff1aSopenharmony_ci#ifndef AVCODEC_FITS_H
23cabdff1aSopenharmony_ci#define AVCODEC_FITS_H
24cabdff1aSopenharmony_ci
25cabdff1aSopenharmony_ci#include <inttypes.h>
26cabdff1aSopenharmony_ci
27cabdff1aSopenharmony_ci#include "libavutil/dict.h"
28cabdff1aSopenharmony_ci
29cabdff1aSopenharmony_citypedef enum FITSHeaderState {
30cabdff1aSopenharmony_ci    STATE_SIMPLE,
31cabdff1aSopenharmony_ci    STATE_XTENSION,
32cabdff1aSopenharmony_ci    STATE_BITPIX,
33cabdff1aSopenharmony_ci    STATE_NAXIS,
34cabdff1aSopenharmony_ci    STATE_NAXIS_N,
35cabdff1aSopenharmony_ci    STATE_PCOUNT,
36cabdff1aSopenharmony_ci    STATE_GCOUNT,
37cabdff1aSopenharmony_ci    STATE_REST,
38cabdff1aSopenharmony_ci} FITSHeaderState;
39cabdff1aSopenharmony_ci
40cabdff1aSopenharmony_ci/**
41cabdff1aSopenharmony_ci * Structure to store the header keywords in FITS file
42cabdff1aSopenharmony_ci */
43cabdff1aSopenharmony_citypedef struct FITSHeader {
44cabdff1aSopenharmony_ci    FITSHeaderState state;
45cabdff1aSopenharmony_ci    unsigned naxis_index;
46cabdff1aSopenharmony_ci    int bitpix;
47cabdff1aSopenharmony_ci    int64_t blank;
48cabdff1aSopenharmony_ci    int blank_found;
49cabdff1aSopenharmony_ci    int naxis;
50cabdff1aSopenharmony_ci    int naxisn[999];
51cabdff1aSopenharmony_ci    int pcount;
52cabdff1aSopenharmony_ci    int gcount;
53cabdff1aSopenharmony_ci    int groups;
54cabdff1aSopenharmony_ci    int rgb; /**< 1 if file contains RGB image, 0 otherwise */
55cabdff1aSopenharmony_ci    int image_extension;
56cabdff1aSopenharmony_ci    double bscale;
57cabdff1aSopenharmony_ci    double bzero;
58cabdff1aSopenharmony_ci    int data_min_found;
59cabdff1aSopenharmony_ci    double data_min;
60cabdff1aSopenharmony_ci    int data_max_found;
61cabdff1aSopenharmony_ci    double data_max;
62cabdff1aSopenharmony_ci} FITSHeader;
63cabdff1aSopenharmony_ci
64cabdff1aSopenharmony_ci
65cabdff1aSopenharmony_ci/**
66cabdff1aSopenharmony_ci * Initialize a single header line
67cabdff1aSopenharmony_ci * @param header pointer to the header
68cabdff1aSopenharmony_ci * @param state current state of parsing the header
69cabdff1aSopenharmony_ci * @return 0 if successful otherwise AVERROR_INVALIDDATA
70cabdff1aSopenharmony_ci */
71cabdff1aSopenharmony_ciint avpriv_fits_header_init(FITSHeader *header, FITSHeaderState state);
72cabdff1aSopenharmony_ci
73cabdff1aSopenharmony_ci/**
74cabdff1aSopenharmony_ci * Parse a single header line
75cabdff1aSopenharmony_ci * @param avcl used in av_log
76cabdff1aSopenharmony_ci * @param header pointer to the header
77cabdff1aSopenharmony_ci * @param line one header line
78cabdff1aSopenharmony_ci * @param metadata used to store metadata while decoding
79cabdff1aSopenharmony_ci * @return 0 if successful otherwise AVERROR_INVALIDDATA
80cabdff1aSopenharmony_ci */
81cabdff1aSopenharmony_ciint avpriv_fits_header_parse_line(void *avcl, FITSHeader *header, const uint8_t line[80], AVDictionary ***metadata);
82cabdff1aSopenharmony_ci
83cabdff1aSopenharmony_ci#endif /* AVCODEC_FITS_H */
84