1 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
2 * See cxx source for full Copyright notice */
5 // $MpId: AliMpSectorReader.h,v 1.7 2006/05/24 13:58:21 ivana Exp $
8 /// \class AliMpSectorReader
9 /// \brief Class that takes care of reading the sector data.
11 /// \author David Guez, Ivana Hrivnacova; IPN Orsay
13 #ifndef ALI_MP_SECTOR_READER_H
14 #define ALI_MP_SECTOR_READER_H
18 #include "AliMpStation12Type.h"
19 #include "AliMpPlaneType.h"
20 #include "AliMpXDirection.h"
30 class AliMpVRowSegmentSpecial;
31 class AliMpMotifReader;
33 class AliMpMotifSpecial;
35 class AliMpDataStreams;
39 class AliMpSectorReader : public TObject
42 AliMpSectorReader(const AliMpDataStreams& dataStreams,
43 AliMq::Station12Type station, AliMp::PlaneType plane);
44 virtual ~AliMpSectorReader();
47 AliMpSector* BuildSector();
53 AliMpSectorReader(const AliMpSectorReader& right);
55 AliMpSectorReader& operator = (const AliMpSectorReader& right);
58 static const TString& GetSectorKeyword();
59 static const TString& GetZoneKeyword();
60 static const TString& GetSubZoneKeyword();
61 static const TString& GetRowKeyword();
62 static const TString& GetSectorSpecialKeyword();
63 static const TString& GetMotifKeyword();
64 static const TString& GetRowSpecialKeyword();
65 static const TString& GetPadRowsKeyword();
66 static const TString& GetPadRowSegmentKeyword();
69 void ReadSectorData(istream& in);
70 void ReadZoneData(istream& in);
71 void ReadSubZoneData(istream& in, AliMpZone* zone);
72 void ReadRowSegmentsData(istream& in,
73 AliMpZone* zone, AliMpSubZone* subZone);
74 AliMpVMotif* ReadMotifData(istream& in, AliMpZone* zone);
75 void ReadSectorSpecialData(istream& in, AliMp::XDirection direction);
76 void ReadMotifsSpecialData(istream& in);
77 void ReadRowSpecialData(istream& in, AliMp::XDirection direction);
78 void ReadRowSegmentSpecialData(istream& in,
79 AliMpVRowSegmentSpecial* segment,
80 AliMp::XDirection direction);
83 const AliMpDataStreams& fkDataStreams; ///< data streams
84 AliMq::Station12Type fStationType; ///< station type
85 AliMp::PlaneType fPlaneType; ///< plane type
86 AliMpSector* fSector; ///< sector
87 AliMpMotifReader* fMotifReader; ///< motif reader
89 ClassDef(AliMpSectorReader,0) // Data reader
92 #endif //ALI_MP_READER_H