source: Sophya/trunk/SophyaProg/PrgUtil/scanfits.cc@ 2368

Last change on this file since 2368 was 2322, checked in by cmv, 23 years ago
  • passage xxstream.h en xxstream
  • compile avec gcc_3.2, gcc_2.96 et cxx En 3.2 le seek from ::end semble marcher (voir Eval/COS/pbseekios.cc)

rz+cmv 11/2/2003

File size: 3.6 KB
Line 
1#include <stdio.h>
2#include <stdlib.h>
3#include <math.h>
4#include <iostream>
5
6#include "histinit.h"
7#include "dvlist.h"
8#include "ntuple.h"
9#include "xntuple.h"
10#include "fitsxntuple.h"
11#include "fitsntuple.h"
12
13/*!
14 \ingroup PrgUtil
15 \file scanfits.cc
16 \brief \b scanfits: Check and scan FITS files
17
18 Scan FITS files and prints information on each FITS bloc in file.
19 Uses the FitsIOServer module.
20
21 \verbatim
22 Usage: scanfits FITSFilename
23 \endverbatim
24 */
25
26string FITSExtType2String(FitsFile::FitsExtensionType exttype)
27{
28 if (exttype == FitsFile::FitsExtensionType_IMAGE) return("IMAGE");
29 else if (exttype == FitsFile::FitsExtensionType_ASCII_TBL) return("ASCII_TBL");
30 else if (exttype == FitsFile::FitsExtensionType_BINARY_TBL) return("BINARY_TBL");
31 else if (exttype == FitsFile::FitsExtensionType_EOF) return("EOF");
32 else if (exttype == FitsFile::FitsExtensionType_ERROR) return("ERROR");
33 else return("Unknown?");
34}
35
36string FITSDataType2String(FitsFile::FitsDataType datatype)
37{
38 if (datatype == FitsFile::FitsDataType_double) return("double");
39 else if (datatype == FitsFile::FitsDataType_float) return("float");
40 else if (datatype == FitsFile::FitsDataType_int) return("int");
41 else if (datatype == FitsFile::FitsDataType_long) return("long");
42 else if (datatype == FitsFile::FitsDataType_byte) return("byte");
43 else if (datatype == FitsFile::FitsDataType_char) return("char");
44 else if (datatype == FitsFile::FitsDataType_ASCII) return("ASCII");
45 else if (datatype == FitsFile::FitsDataType_NULL) return("NULL");
46 else return("Unknown?");
47}
48
49int main(int narg, char *arg[])
50{
51 if (narg < 2) {
52 cerr << "scanfits/Erreur arg - Usage scanfits nomfits \n" << endl;
53 exit(0);
54 }
55 try {
56 SophyaInit();
57 string flnm = arg[1];
58 int nbblk = FitsInFile::NbBlocks(arg[1]);
59 cout << " :::::::: File " << flnm << " has " << nbblk << " blocks "
60 << " :::::::: " << endl;
61
62 // cout << " FitsFile::FitsExtensionType : FitsExtensionType_IMAGE= " <<
63 // (int)FitsFile::FitsExtensionType_IMAGE <<
64 // " FitsExtensionType_ASCII_TBL= " << (int)FitsFile::FitsExtensionType_ASCII_TBL <<
65 // " FitsExtensionType_BINARY_TBL= " << (int)FitsFile::FitsExtensionType_BINARY_TBL << endl;
66 // cout << " FitsFile::FitsDataType: FitsDataType_double= " <<
67 // (int)FitsFile::FitsDataType_double <<
68 // " FitsDataType_float= " << (int)FitsFile::FitsDataType_float <<
69 // " FitsDataType_int= " << (int)FitsFile::FitsDataType_int <<
70 // " FitsDataType_char= " << (int)FitsFile::FitsDataType_char <<
71 // " FitsDataType_ASCII= " << (int)FitsFile::FitsDataType_ASCII << endl << endl;
72
73 for(int i=1; i<=nbblk; i++) {
74 int naxis;
75 vector<int> axis;
76 DVList header;
77 FitsFile::FitsExtensionType exttype;
78 FitsFile::FitsDataType datatype;
79
80 FitsInFile::GetBlockType(arg[1], i, exttype, naxis, axis, datatype, header);
81 cout << "\n--------- Header Num " << i << " Type " << FITSExtType2String(exttype)
82 << " --- NAxis= " << naxis
83 << " DataType= " << FITSDataType2String(datatype) << endl;
84 if (axis.size() > 0) {
85 cout << " >> Axis Sizes: " ;
86 for(int j=0; j<axis.size(); j++) {
87 if (j > 0) cout << " x " ;
88 cout << axis[j] ;
89 }
90 cout << endl;
91 }
92 cout << " >>> Header info : " ;
93 cout << header << endl;
94 cout << "----------------------------------------------------------------------"
95 << endl;
96 }
97
98 }
99 catch (PThrowable & exc) {
100 cerr << "sanfits: Catched Exception " << (string)typeid(exc).name()
101 << "\n .... Msg= " << exc.Msg() << endl;
102 }
103 catch (...) {
104 cerr << " some other exception was caught ! " << endl;
105 }
106
107}
Note: See TracBrowser for help on using the repository browser.