]>
Commit | Line | Data |
---|---|---|
47c194a6 | 1 | #ifndef ALIMUONBLOCKHEADER_H |
2 | #define ALIMUONBLOCKHEADER_H | |
3 | /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. * | |
4 | * See cxx source for full Copyright notice */ | |
5 | ||
6 | /*$Id$*/ | |
7 | ||
8 | /// \ingroup raw | |
9 | /// \class AliMUONBlockHeader | |
84ceeb06 | 10 | /// \brief MUON block (Crocus CRT) header for tracker event |
47c194a6 | 11 | /// |
78649106 | 12 | // Author Christian Finck |
47c194a6 | 13 | |
14 | #include <TObject.h> | |
15 | #include <TClonesArray.h> | |
16 | ||
17 | class AliMUONDspHeader; | |
18 | ||
19 | class AliMUONBlockHeader : public TObject { | |
20 | ||
21 | public: | |
22 | AliMUONBlockHeader(); | |
ce350193 | 23 | AliMUONBlockHeader(TRootIOCtor* dummy); |
47c194a6 | 24 | AliMUONBlockHeader(const AliMUONBlockHeader &event); |
25 | AliMUONBlockHeader& operator=(const AliMUONBlockHeader &event); | |
26 | ||
27 | virtual ~AliMUONBlockHeader(); | |
28 | ||
71a2d3aa | 29 | // |
47c194a6 | 30 | // Block header |
71a2d3aa | 31 | // |
32 | /// Return data key word for CRT header | |
84ceeb06 | 33 | Int_t GetDataKey() const {return fDataKey;} |
71a2d3aa | 34 | /// Return total length of block structure (w/o padding word) |
47c194a6 | 35 | Int_t GetTotalLength() const {return fTotalLength;} |
71a2d3aa | 36 | /// Return length of raw data |
47c194a6 | 37 | Int_t GetLength() const {return fLength;} |
71a2d3aa | 38 | /// Return Dsp id |
47c194a6 | 39 | Int_t GetDspId() const {return fDspId;} |
71a2d3aa | 40 | /// Return L0 trigger word |
84ceeb06 | 41 | Int_t GetL0Trigger() const {return fL0Trigger;} |
71a2d3aa | 42 | /// Return Bunch Crossing for mini-event id (see TDR chapter 8) |
84ceeb06 | 43 | Int_t GetMiniEventId() const {return fMiniEventId;} |
71a2d3aa | 44 | /// Return Event Id in bunch crossing |
84ceeb06 | 45 | Int_t GetEventId1() const {return fEventId1;} |
71a2d3aa | 46 | /// Return Event Id in orbit number |
84ceeb06 | 47 | Int_t GetEventId2() const {return fEventId2;} |
48 | ||
71a2d3aa | 49 | /// Return header length in word |
47c194a6 | 50 | Int_t GetHeaderLength() const {return fgkHeaderLength;} |
71a2d3aa | 51 | /// Return default data key word for CRT header |
84ceeb06 | 52 | UInt_t GetDefaultDataKey() const {return fgkDefaultDataKey;} |
1c66abf3 | 53 | /// Return data key end word for CRT header |
54 | UInt_t GetDdlDataKey() const {return fgkDdlDataKey;} | |
71a2d3aa | 55 | |
56 | /// Set data key word for CRT header | |
84ceeb06 | 57 | void SetDataKey(Int_t d) {fDataKey = d;} |
71a2d3aa | 58 | /// Set total length of block structure (w/o padding word) |
47c194a6 | 59 | void SetTotalLength(Int_t l) {fTotalLength = l;} |
71a2d3aa | 60 | /// Set length of raw data |
47c194a6 | 61 | void SetLength(Int_t l) {fLength = l;} |
71a2d3aa | 62 | /// Set Dsp id |
47c194a6 | 63 | void SetDspId(Int_t d) {fDspId = d;} |
71a2d3aa | 64 | /// Set L0 trigger word |
84ceeb06 | 65 | void SetL0Trigger(Int_t l) {fL0Trigger = l;} |
71a2d3aa | 66 | /// Set Bunch Crossing for mini-event id (see TDR chapter 8) |
84ceeb06 | 67 | void SetMiniEventId(Int_t e) {fMiniEventId = e;} |
71a2d3aa | 68 | /// Set Event Id in bunch crossing |
84ceeb06 | 69 | void SetEventId1(Int_t e) {fEventId1 = e;} |
71a2d3aa | 70 | /// Set Event Id in orbit number |
84ceeb06 | 71 | void SetEventId2(Int_t e) {fEventId2 = e;} |
71a2d3aa | 72 | |
73 | ||
74 | /// Return header | |
84ceeb06 | 75 | Int_t* GetHeader() {return &fDataKey;} |
47c194a6 | 76 | |
77 | void AddDspHeader(const AliMUONDspHeader& dspHeader); | |
78 | ||
71a2d3aa | 79 | /// get TClonesArray |
47c194a6 | 80 | TClonesArray* GetDspHeaderArray() const {return fDspHeaderArray;} |
81 | ||
71a2d3aa | 82 | /// get entries |
47c194a6 | 83 | Int_t GetDspHeaderEntries() const {return fDspHeaderArray->GetEntriesFast();} |
84 | ||
71a2d3aa | 85 | /// get entry |
47c194a6 | 86 | AliMUONDspHeader* GetDspHeaderEntry(Int_t i) const { |
87 | return (AliMUONDspHeader*)fDspHeaderArray->At(i);} | |
88 | ||
89 | // clear | |
90 | void Clear(Option_t* opt); | |
91 | ||
1ed3c5c2 | 92 | // print out |
93 | void Print(Option_t* /*opt*/) const; | |
94 | ||
47c194a6 | 95 | private: |
96 | ||
97 | // block header | |
84ceeb06 | 98 | Int_t fDataKey; ///< Data key word for CRT header |
829425a5 | 99 | Int_t fTotalLength; ///< total length of block structure (w/o padding word) |
100 | Int_t fLength; ///< length of raw data | |
101 | Int_t fDspId; ///< Dsp id | |
84ceeb06 | 102 | Int_t fL0Trigger; ///< L0 trigger word |
103 | Int_t fMiniEventId; ///< Bunch Crossing for mini-event id (see TDR chapter 8) | |
104 | Int_t fEventId1; ///< Event Id in bunch crossing | |
105 | Int_t fEventId2; ///< Event Id in orbit number | |
106 | ||
107 | ||
1c66abf3 | 108 | static const Int_t fgkHeaderLength; ///< header length in word |
109 | static const UInt_t fgkDefaultDataKey; ///< default data key word for CRT header | |
110 | static const UInt_t fgkDdlDataKey; ///< data key end word for CRT header | |
47c194a6 | 111 | |
829425a5 | 112 | TClonesArray* fDspHeaderArray; ///< array of block header |
47c194a6 | 113 | |
1c66abf3 | 114 | ClassDef(AliMUONBlockHeader,3) // MUON block header for Tracker event |
47c194a6 | 115 | }; |
116 | #endif |