1 #ifndef ALIMUONRAWSTREAMTRIGGER_H
2 #define ALIMUONRAWSTREAMTRIGGER_H
3 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
9 /// \class AliMUONRawStreamTrigger
10 /// \brief Class for reading MUON raw digits
12 // Author: Christian Finck
15 #include "AliMUONPayloadTrigger.h"
18 class AliMUONDDLTrigger;
21 class AliMUONRawStreamTrigger: public TObject {
23 AliMUONRawStreamTrigger();
24 AliMUONRawStreamTrigger(AliRawReader* rawReader);
25 virtual ~AliMUONRawStreamTrigger();
27 virtual Bool_t Next();
28 virtual Bool_t NextDDL();
30 /// Return maximum number of DDL in DATE file
31 Int_t GetMaxDDL() const {return fMaxDDL;}
32 /// Return maximum number of regional cards in DATE file
33 Int_t GetMaxReg() const {return fPayload->GetMaxReg();}
34 /// Return maximum number of local cards in DATE file
35 Int_t GetMaxLoc() const {return fPayload->GetMaxLoc();}
38 void SetMaxDDL(Int_t ddl);
39 void SetMaxReg(Int_t reg);
40 void SetMaxLoc(Int_t loc);
42 /// Set object for reading the raw data
43 void SetReader(AliRawReader* rawReader) {fRawReader = rawReader;}
45 /// Return pointer for DDL structure
46 AliMUONDDLTrigger* GetDDLTrigger() const {return fPayload->GetDDLTrigger();}
47 /// Return number of DDL
48 Int_t GetDDL() const {return fDDL - 1;}
52 AliMUONRawStreamTrigger(const AliMUONRawStreamTrigger& stream);
54 AliMUONRawStreamTrigger& operator = (const AliMUONRawStreamTrigger& stream);
56 AliRawReader* fRawReader; ///< object for reading the raw data
57 AliMUONPayloadTrigger* fPayload; ///< pointer to payload decoder
59 Int_t fDDL; ///< number of DDL
60 Int_t fSubEntries; ///< entries of buspatch structure
61 Bool_t fNextDDL; ///< flag for next DDL to be read
62 Int_t fMaxDDL; ///< maximum number of DDL in DATE file
64 ClassDef(AliMUONRawStreamTrigger, 3) // base class for reading MUON trigger rawdata