1 /**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
18 #include "AliMUONDDLTracker.h"
19 #include "AliMUONBusStruct.h"
20 #include "AliMUONDspHeader.h"
21 #include "AliMUONBlockHeader.h"
24 //-----------------------------------------------------------------------------
25 /// \class AliMUONDDLTracker
27 /// A wrapper object for 1 DDL of the MUON tracking chambers.
30 //-----------------------------------------------------------------------------
33 ClassImp(AliMUONDDLTracker)
36 //___________________________________________
37 AliMUONDDLTracker::AliMUONDDLTracker(TRootIOCtor* /*dummy*/)
46 //___________________________________________
47 AliMUONDDLTracker::AliMUONDDLTracker()
49 fBlkHeaderArray(new TClonesArray("AliMUONBlockHeader", 2))
57 //___________________________________________
58 AliMUONDDLTracker::~AliMUONDDLTracker()
63 fBlkHeaderArray->Delete();
64 delete fBlkHeaderArray;
68 //___________________________________________
69 void AliMUONDDLTracker::AddBusPatch(const AliMUONBusStruct& busPatch, Int_t iBlock, Int_t iDsp )
71 /// adding bus patch informations
72 /// for a given block & Dsp structure
73 /// using TClonesArrays
75 AliMUONBlockHeader* blockHeader = (AliMUONBlockHeader*)fBlkHeaderArray->At(iBlock);
76 AliMUONDspHeader* dspHeader = (AliMUONDspHeader*)blockHeader->GetDspHeaderEntry(iDsp);
78 TClonesArray* busPatchArray = (TClonesArray*)dspHeader->GetBusPatchArray();
80 TClonesArray &eventArray = *busPatchArray;
81 new(eventArray[eventArray.GetEntriesFast()]) AliMUONBusStruct(busPatch);
84 //___________________________________________
85 void AliMUONDDLTracker::AddDspHeader(const AliMUONDspHeader& dspHeader, Int_t iBlock)
87 /// adding DspHeader informations
88 /// for a given block structure
89 /// using TClonesArrays
91 AliMUONBlockHeader* blockHeader = (AliMUONBlockHeader*)fBlkHeaderArray->At(iBlock);
93 TClonesArray* dspHeaderArray = (TClonesArray*)blockHeader->GetDspHeaderArray();
95 TClonesArray &dspArray = *dspHeaderArray;
96 new(dspArray[dspArray.GetEntriesFast()]) AliMUONDspHeader(dspHeader);
99 //___________________________________________
100 void AliMUONDDLTracker::AddBlkHeader(const AliMUONBlockHeader& blkHeader)
102 /// adding Block header informations
103 /// for a given block structure
104 /// using TClonesArrays
106 TClonesArray &blkArray = *fBlkHeaderArray;
107 new(blkArray[blkArray.GetEntriesFast()]) AliMUONBlockHeader(blkHeader);
110 //___________________________________________
111 void AliMUONDDLTracker::Clear(Option_t* )
113 /// Clear TClones arrays
114 /// instead of deleting
116 fBlkHeaderArray->Clear("C");