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 */
9 /// \class AliMUONBlockHeader
10 /// \brief MUON block (Crocus CRT) header for tracker event
12 /// \author Christian Finck
15 #include <TClonesArray.h>
17 class AliMUONDspHeader;
19 class AliMUONBlockHeader : public TObject {
23 AliMUONBlockHeader(const AliMUONBlockHeader &event);
24 AliMUONBlockHeader& operator=(const AliMUONBlockHeader &event);
26 virtual ~AliMUONBlockHeader();
29 Int_t GetDataKey() const {return fDataKey;}
30 Int_t GetTotalLength() const {return fTotalLength;}
31 Int_t GetLength() const {return fLength;}
32 Int_t GetDspId() const {return fDspId;}
33 Int_t GetL0Trigger() const {return fL0Trigger;}
34 Int_t GetMiniEventId() const {return fMiniEventId;}
35 Int_t GetEventId1() const {return fEventId1;}
36 Int_t GetEventId2() const {return fEventId2;}
38 Int_t GetHeaderLength() const {return fgkHeaderLength;}
39 UInt_t GetDefaultDataKey() const {return fgkDefaultDataKey;}
41 void SetDataKey(Int_t d) {fDataKey = d;}
42 void SetTotalLength(Int_t l) {fTotalLength = l;}
43 void SetLength(Int_t l) {fLength = l;}
44 void SetDspId(Int_t d) {fDspId = d;}
45 void SetL0Trigger(Int_t l) {fL0Trigger = l;}
46 void SetMiniEventId(Int_t e) {fMiniEventId = e;}
47 void SetEventId1(Int_t e) {fEventId1 = e;}
48 void SetEventId2(Int_t e) {fEventId2 = e;}
50 Int_t* GetHeader() {return &fDataKey;}
52 void AddDspHeader(const AliMUONDspHeader& dspHeader);
55 TClonesArray* GetDspHeaderArray() const {return fDspHeaderArray;}
58 Int_t GetDspHeaderEntries() const {return fDspHeaderArray->GetEntriesFast();}
61 AliMUONDspHeader* GetDspHeaderEntry(Int_t i) const {
62 return (AliMUONDspHeader*)fDspHeaderArray->At(i);}
65 void Clear(Option_t* opt);
70 Int_t fDataKey; ///< Data key word for CRT header
71 Int_t fTotalLength; ///< total length of block structure (w/o padding word)
72 Int_t fLength; ///< length of raw data
73 Int_t fDspId; ///< Dsp id
74 Int_t fL0Trigger; ///< L0 trigger word
75 Int_t fMiniEventId; ///< Bunch Crossing for mini-event id (see TDR chapter 8)
76 Int_t fEventId1; ///< Event Id in bunch crossing
77 Int_t fEventId2; ///< Event Id in orbit number
80 static const Int_t fgkHeaderLength; ///< header length in word
81 static const UInt_t fgkDefaultDataKey; ///< default data key word for CRT header
83 TClonesArray* fDspHeaderArray; ///< array of block header
85 ClassDef(AliMUONBlockHeader,2) // MUON block header for Tracker event