6 // Class that takes care of reading the sector data.
8 // Authors: David Guez, Ivana Hrivnacova; IPN Orsay
10 #ifndef ALI_MP_READER_H
11 #define ALI_MP_READER_H
18 #include "AliMpSectorTypes.h"
19 #include "AliMpStationType.h"
20 #include "AliMpPlaneType.h"
21 #include "AliMpXDirection.h"
22 #include "AliMpIntPair.h"
28 class AliMpVRowSegmentSpecial;
30 class AliMpMotifSpecial;
33 class AliMpReader : public TObject
36 AliMpReader(AliMpStationType station, AliMpPlaneType plane);
38 virtual ~AliMpReader();
41 AliMpSector* BuildSector();
42 AliMpMotifType* BuildMotifType(const TString& motifTypeId);
43 AliMpMotifSpecial* BuildMotifSpecial(const TString& motifID,
44 AliMpMotifType* motifType);
47 void SetVerboseLevel(Int_t verboseLevel);
51 static const Int_t fgkSeparator; // the separator used for conversion
55 Int_t GetIndex(const string& s) const;
56 Int_t GetIndex(const AliMpIntPair& pair) const;
57 string GetString(Int_t index) const;
58 AliMpIntPair GetPair(Int_t index) const;
62 void ReadSectorData(ifstream& in);
63 void ReadZoneData(ifstream& in);
64 void ReadSubZoneData(ifstream& in, AliMpZone* zone);
65 void ReadRowSegmentsData(ifstream& in,
66 AliMpZone* zone, AliMpSubZone* subZone);
67 AliMpVMotif* ReadMotifData(ifstream& in, AliMpZone* zone);
68 void ReadSectorSpecialData(ifstream& in, AliMpXDirection direction);
69 void ReadMotifsSpecialData(ifstream& in);
70 void ReadRowSpecialData(ifstream& in, AliMpXDirection direction);
71 void ReadRowSegmentSpecialData(ifstream& in,
72 AliMpVRowSegmentSpecial* segment,
73 AliMpXDirection direction);
75 // static data members
76 static const TString fgkSectorKeyword; // sector keyword
77 static const TString fgkZoneKeyword; // zone keyword
78 static const TString fgkSubZoneKeyword; // subzone keyword
79 static const TString fgkRowKeyword; // row keyword
80 static const TString fgkEofKeyword; // eof keyword
81 static const TString fgkSectorSpecialKeyword; // sector special keyword
82 static const TString fgkMotifKeyword; // motif keyword
83 static const TString fgkRowSpecialKeyword; // row special keyword
84 static const TString fgkPadRowsKeyword; // pad rows keyword
85 static const TString fgkPadRowSegmentKeyword; // pad row segment keyword
88 AliMpStationType fStationType; // station type
89 AliMpPlaneType fPlaneType; // plane type
90 AliMpSector* fSector; // sector
91 Int_t fVerboseLevel;// verbose level
93 ClassDef(AliMpReader,1) // Data reader
96 #endif //ALI_MP_READER_H