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
14 ///////////////////////////////////////////////////////////////////////////////
16 /// This class provides access to MUON digits in raw data.
18 ///////////////////////////////////////////////////////////////////////////////
21 #include <TClonesArray.h>
22 #include "AliMUONPayloadTrigger.h"
25 class AliMUONDDLTrigger;
28 class AliMUONRawStreamTrigger: public TObject {
30 AliMUONRawStreamTrigger();
31 AliMUONRawStreamTrigger(AliRawReader* rawReader);
32 AliMUONRawStreamTrigger(const AliMUONRawStreamTrigger& stream);
33 AliMUONRawStreamTrigger& operator = (const AliMUONRawStreamTrigger& stream);
34 virtual ~AliMUONRawStreamTrigger();
36 virtual Bool_t Next();
37 virtual Bool_t NextDDL();
39 Int_t GetMaxDDL() const {return fMaxDDL;}
40 Int_t GetMaxReg() const {return fPayload->GetMaxReg();}
41 Int_t GetMaxLoc() const {return fPayload->GetMaxLoc();}
44 void SetMaxDDL(Int_t ddl);
45 void SetMaxReg(Int_t reg);
46 void SetMaxLoc(Int_t loc);
49 void SetReader(AliRawReader* rawReader) {fRawReader = rawReader;}
51 AliMUONDDLTrigger* GetDDLTrigger() const {return fPayload->GetDDLTrigger();}
52 Int_t GetDDL() const {return fDDL - 1;}
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