| 1 | #ifndef MARS_MTopFitsGroup
|
|---|
| 2 | #define MARS_MTopFitsGroup
|
|---|
| 3 |
|
|---|
| 4 | #include <sys/types.h>
|
|---|
| 5 | #include <sys/stat.h>
|
|---|
| 6 |
|
|---|
| 7 | #ifndef ROOT_TString
|
|---|
| 8 | #include <TString.h>
|
|---|
| 9 | #endif
|
|---|
| 10 |
|
|---|
| 11 | #ifndef MARS_fits
|
|---|
| 12 | #include "fits.h"
|
|---|
| 13 | #endif
|
|---|
| 14 |
|
|---|
| 15 | #ifndef MARS_ofits
|
|---|
| 16 | #include "ofits.h"
|
|---|
| 17 | #endif
|
|---|
| 18 |
|
|---|
| 19 | ///////////////////////////////////////////////////////////////////////////////
|
|---|
| 20 | // An unique id of files. It is sortable, i. e. can be uses as a key in maps
|
|---|
| 21 | class MUniqueFileId
|
|---|
| 22 | {
|
|---|
| 23 | dev_t fst_dev; // id of the device of this file
|
|---|
| 24 | ino_t fst_ino; // inode number of the file on the device fst_dev
|
|---|
| 25 |
|
|---|
| 26 | public:
|
|---|
| 27 | MUniqueFileId(dev_t st_dev, ino_t st_ino)
|
|---|
| 28 | : fst_dev(st_dev), fst_ino(st_ino) {}
|
|---|
| 29 |
|
|---|
| 30 | bool operator < (const MUniqueFileId & fileId) const
|
|---|
| 31 | { if (fst_dev == fileId.fst_dev)
|
|---|
| 32 | return fst_ino < fileId.fst_ino;
|
|---|
| 33 | return fst_dev < fileId.fst_dev; }
|
|---|
| 34 |
|
|---|
| 35 | };
|
|---|
| 36 |
|
|---|
| 37 | ///////////////////////////////////////////////////////////////////////////////
|
|---|
| 38 | // All information of one open Top Level FITS group
|
|---|
| 39 | class MTopFitsGroup
|
|---|
| 40 | {
|
|---|
| 41 | // filename of the group, but expanded by ROOT
|
|---|
| 42 | // ( see gSystem->ExpandPathName() )
|
|---|
| 43 | TString fFileName;
|
|---|
| 44 |
|
|---|
| 45 | // the top level group as AstroROOT-2 data structure
|
|---|
| 46 | ofits* fTopGroup;
|
|---|
| 47 |
|
|---|
| 48 | // number of usage of this group by different MWriteFitsFile instances
|
|---|
| 49 | Int_t fNumOpen;
|
|---|
| 50 |
|
|---|
| 51 | public:
|
|---|
| 52 | MTopFitsGroup(const char * fileName, ofits* file) : fFileName(fileName),
|
|---|
| 53 | fTopGroup(file),
|
|---|
| 54 | fNumOpen(1)
|
|---|
| 55 | {}
|
|---|
| 56 |
|
|---|
| 57 | void IncreaseUsage() {++fNumOpen;}
|
|---|
| 58 | void DecreaseUsage() {--fNumOpen;}
|
|---|
| 59 | Int_t GetNumUsage() {return fNumOpen;}
|
|---|
| 60 |
|
|---|
| 61 | void Attach(ofits* table);
|
|---|
| 62 | Bool_t GetNextChild(ofits* table);
|
|---|
| 63 |
|
|---|
| 64 | ofits* GetGroup() {return fTopGroup;}
|
|---|
| 65 | const TString &GetFileName() const {return fFileName;}
|
|---|
| 66 |
|
|---|
| 67 | };
|
|---|
| 68 |
|
|---|
| 69 | #endif
|
|---|
| 70 |
|
|---|