]>
Commit | Line | Data |
---|---|---|
d04aea32 | 1 | // @(#) $Id$ |
5ea08be4 | 2 | // Author: Fons Rademakers 26/11/99 |
5ea08be4 | 3 | |
35aa01d6 | 4 | /************************************************************************** |
5 | * Copyright(c) 1998-2003, ALICE Experiment at CERN, All rights reserved. * | |
6 | * * | |
7 | * Author: The ALICE Off-line Project. * | |
8 | * Contributors are mentioned in the code where appropriate. * | |
9 | * * | |
10 | * Permission to use, copy, modify and distribute this software and its * | |
11 | * documentation strictly for non-commercial purposes is hereby granted * | |
12 | * without fee, provided that the above copyright notice appears in all * | |
13 | * copies and that both the copyright notice and this permission notice * | |
14 | * appear in the supporting documentation. The authors make no claims * | |
15 | * about the suitability of this software for any purpose. It is * | |
16 | * provided "as is" without express or implied warranty. * | |
17 | **************************************************************************/ | |
18 | ||
19 | ////////////////////////////////////////////////////////////////////////// | |
20 | // // | |
21 | // AliRawEvent // | |
22 | // // | |
23 | // Set of classes defining the ALICE RAW event format. The AliRawEvent // | |
24 | // class defines a RAW event. It consists of an AliEventHeader object // | |
25 | // an AliEquipmentHeader object, an AliRawData object and an array of // | |
26 | // sub-events, themselves also being AliRawEvents. The number of // | |
27 | // sub-events depends on the number of DATE LDC's. // | |
28 | // The AliRawEvent objects are written to a ROOT file using different // | |
29 | // technologies, i.e. to local disk via AliRawDB or via rfiod using // | |
30 | // AliRawRFIODB or via rootd using AliRawRootdDB or to CASTOR via // | |
31 | // rootd using AliRawCastorDB (and for performance testing there is // | |
32 | // also AliRawNullDB). // | |
35aa01d6 | 33 | // The AliStats class provides statics information that is added as // |
34 | // a single keyed object to each raw file. // | |
35 | // The AliTagDB provides an interface to a TAG database. // | |
36 | // The AliMDC class is usid by the "alimdc" stand-alone program // | |
37 | // that reads data directly from DATE. // | |
38 | // // | |
39 | ////////////////////////////////////////////////////////////////////////// | |
40 | ||
a197a4ce | 41 | #include <TObjArray.h> |
5ea08be4 | 42 | |
f2dc6b20 | 43 | #include "AliLog.h" |
44 | ||
45 | #include "AliRawEventHeaderBase.h" | |
94d918a7 | 46 | #include "AliRawEquipment.h" |
5ea08be4 | 47 | |
48 | #include "AliRawEvent.h" | |
49 | ||
5ea08be4 | 50 | |
51 | ClassImp(AliRawEvent) | |
5ea08be4 | 52 | |
5ea08be4 | 53 | |
54 | //______________________________________________________________________________ | |
f3c1e83c | 55 | AliRawEvent::AliRawEvent(): |
56 | fNEquipments(0), | |
57 | fNSubEvents(0), | |
58 | fEvtHdr(NULL), | |
59 | fEquipments(NULL), | |
60 | fSubEvents(NULL) | |
5ea08be4 | 61 | { |
a197a4ce | 62 | // Create ALICE event object. If ownData is kFALSE we will use a static |
63 | // raw data object, otherwise a private copy will be made. | |
5ea08be4 | 64 | |
5ea08be4 | 65 | } |
66 | ||
c51de60d | 67 | //______________________________________________________________________________ |
f2dc6b20 | 68 | AliRawEventHeaderBase *AliRawEvent::GetHeader(char*& data) |
c51de60d | 69 | { |
f2dc6b20 | 70 | // Get event header part of AliRawEvent. |
71 | // First the DATE version is identified and then the | |
72 | // corresponding event header version object is created | |
73 | ||
74 | if (!fEvtHdr) { | |
75 | fEvtHdr = AliRawEventHeaderBase::Create(data); | |
76 | } | |
77 | ||
78 | return fEvtHdr; | |
79 | } | |
c51de60d | 80 | |
f2dc6b20 | 81 | //______________________________________________________________________________ |
82 | AliRawEventHeaderBase *AliRawEvent::GetHeader() | |
83 | { | |
84 | if (!fEvtHdr) { | |
85 | AliFatal("Header version not yet initialized!"); | |
86 | return 0x0; | |
87 | } | |
c51de60d | 88 | |
f2dc6b20 | 89 | return fEvtHdr; |
c51de60d | 90 | } |
91 | ||
5ea08be4 | 92 | //______________________________________________________________________________ |
94d918a7 | 93 | AliRawEquipment *AliRawEvent::NextEquipment() |
5ea08be4 | 94 | { |
94d918a7 | 95 | // Returns next equipment object. |
96 | ||
97 | if (!fEquipments) | |
98 | fEquipments = new TObjArray(100); // arbitrary, probably enough to prevent resizing | |
99 | ||
100 | if (fEquipments->GetSize() <= fNEquipments) { | |
101 | fEquipments->Expand(fNEquipments+10); | |
102 | Warning("NextEquipment", "expanded fEquipments by 10 to %d", | |
103 | fEquipments->GetSize()); | |
104 | } | |
5ea08be4 | 105 | |
94d918a7 | 106 | AliRawEquipment *eq; |
107 | if (!(eq = (AliRawEquipment *)fEquipments->At(fNEquipments))) { | |
108 | eq = new AliRawEquipment; | |
109 | fEquipments->AddAt(eq, fNEquipments); | |
110 | } | |
111 | ||
112 | fNEquipments++; | |
5ea08be4 | 113 | |
94d918a7 | 114 | return eq; |
5ea08be4 | 115 | } |
116 | ||
117 | //______________________________________________________________________________ | |
94d918a7 | 118 | AliRawEquipment *AliRawEvent::GetEquipment(Int_t index) const |
5ea08be4 | 119 | { |
94d918a7 | 120 | // Get specified equipment. Returns 0 if equipment does not exist. |
5ea08be4 | 121 | |
94d918a7 | 122 | if (!fEquipments) |
123 | return 0; | |
5ea08be4 | 124 | |
94d918a7 | 125 | return (AliRawEquipment *) fEquipments->At(index); |
5ea08be4 | 126 | } |
127 | ||
128 | //______________________________________________________________________________ | |
129 | AliRawEvent *AliRawEvent::NextSubEvent() | |
130 | { | |
131 | // Returns next sub-event object. | |
132 | ||
133 | if (!fSubEvents) | |
134 | fSubEvents = new TObjArray(100); // arbitrary, probably enough to prevent resizing | |
135 | ||
136 | if (fSubEvents->GetSize() <= fNSubEvents) { | |
137 | fSubEvents->Expand(fNSubEvents+10); | |
138 | Warning("NextSubEvent", "expanded fSubEvents by 10 to %d", | |
139 | fSubEvents->GetSize()); | |
140 | } | |
141 | ||
142 | AliRawEvent *ev; | |
143 | if (!(ev = (AliRawEvent *)fSubEvents->At(fNSubEvents))) { | |
144 | ev = new AliRawEvent; | |
145 | fSubEvents->AddAt(ev, fNSubEvents); | |
146 | } | |
147 | ||
148 | fNSubEvents++; | |
149 | ||
150 | return ev; | |
151 | } | |
152 | ||
04fa961a | 153 | //______________________________________________________________________________ |
5459c838 | 154 | AliRawEvent *AliRawEvent::GetSubEvent(Int_t index) const |
04fa961a | 155 | { |
5459c838 | 156 | // Get specified sub event. Returns 0 if sub event does not exist. |
157 | ||
158 | if (!fSubEvents) | |
159 | return 0; | |
160 | ||
161 | return (AliRawEvent *) fSubEvents->At(index); | |
04fa961a | 162 | } |
163 | ||
5ea08be4 | 164 | //______________________________________________________________________________ |
165 | void AliRawEvent::Reset() | |
166 | { | |
167 | // Reset the event in case it needs to be re-used (avoiding costly | |
168 | // new/delete cycle). We reset the size marker for the AliRawData | |
169 | // objects and the sub event counter. | |
170 | ||
94d918a7 | 171 | for (int i = 0; i < fNEquipments; i++) { |
172 | AliRawEquipment *eq = (AliRawEquipment *)fEquipments->At(i); | |
173 | eq->Reset(); | |
174 | } | |
175 | fNEquipments = 0; | |
5ea08be4 | 176 | for (int i = 0; i < fNSubEvents; i++) { |
177 | AliRawEvent *ev = (AliRawEvent *)fSubEvents->At(i); | |
94d918a7 | 178 | ev->Reset(); |
5ea08be4 | 179 | } |
180 | fNSubEvents = 0; | |
181 | } | |
182 | ||
183 | //______________________________________________________________________________ | |
184 | AliRawEvent::~AliRawEvent() | |
185 | { | |
186 | // Clean up event object. Delete also, possible, private raw data. | |
187 | ||
188 | delete fEvtHdr; | |
94d918a7 | 189 | if (fEquipments) |
190 | fEquipments->Delete(); | |
191 | delete fEquipments; | |
5ea08be4 | 192 | if (fSubEvents) |
193 | fSubEvents->Delete(); | |
194 | delete fSubEvents; | |
195 | } |