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 **************************************************************************/
16 #include "AliMUONDDLTracker.h"
17 #include "AliMUONBusStruct.h"
18 #include "AliMUONDspHeader.h"
19 #include "AliMUONBlockHeader.h"
21 ClassImp(AliMUONDDLTracker)
25 /// \class AliMUONDDLTracker
27 /// A wrapper object for 1 DDL of the MUON tracking chambers.
32 //___________________________________________
33 AliMUONDDLTracker::AliMUONDDLTracker()
39 fBlkHeaderArray = new TClonesArray("AliMUONBlockHeader", 2);
43 //___________________________________________
44 AliMUONDDLTracker::~AliMUONDDLTracker()
49 fBlkHeaderArray->Delete();
50 delete fBlkHeaderArray;
54 //___________________________________________
55 void AliMUONDDLTracker::AddBusPatch(const AliMUONBusStruct& busPatch, Int_t iBlock, Int_t iDsp )
57 // adding bus patch informations
58 // for a given block & Dsp structure
59 // using TClonesArrays
61 AliMUONBlockHeader* blockHeader = (AliMUONBlockHeader*)fBlkHeaderArray->At(iBlock);
62 AliMUONDspHeader* dspHeader = (AliMUONDspHeader*)blockHeader->GetDspHeaderEntry(iDsp);
64 TClonesArray* busPatchArray = (TClonesArray*)dspHeader->GetBusPatchArray();
66 TClonesArray &eventArray = *busPatchArray;
67 new(eventArray[eventArray.GetEntriesFast()]) AliMUONBusStruct(busPatch);
70 //___________________________________________
71 void AliMUONDDLTracker::AddDspHeader(const AliMUONDspHeader& dspHeader, Int_t iBlock)
73 // adding DspHeader informations
74 // for a given block structure
75 // using TClonesArrays
77 AliMUONBlockHeader* blockHeader = (AliMUONBlockHeader*)fBlkHeaderArray->At(iBlock);
79 TClonesArray* dspHeaderArray = (TClonesArray*)blockHeader->GetDspHeaderArray();
81 TClonesArray &dspArray = *dspHeaderArray;
82 new(dspArray[dspArray.GetEntriesFast()]) AliMUONDspHeader(dspHeader);
85 //___________________________________________
86 void AliMUONDDLTracker::AddBlkHeader(const AliMUONBlockHeader& blkHeader)
88 TClonesArray &blkArray = *fBlkHeaderArray;
89 new(blkArray[blkArray.GetEntriesFast()]) AliMUONBlockHeader(blkHeader);
92 //___________________________________________
93 void AliMUONDDLTracker::Clear(Option_t* )
95 // Clear TClones arrays
96 // instead of deleting
98 fBlkHeaderArray->Clear("C");