Finally a working version of raw-data event cloning. It turned out to be quite diffic...
authorcvetan <cvetan@f7af4fe6-9843-0410-8265-dc069ae4e863>
Fri, 4 Sep 2009 19:52:00 +0000 (19:52 +0000)
committercvetan <cvetan@f7af4fe6-9843-0410-8265-dc069ae4e863>
Fri, 4 Sep 2009 19:52:00 +0000 (19:52 +0000)
RAW/AliRawEquipment.cxx
RAW/AliRawEquipment.h
RAW/AliRawEquipmentV2.cxx
RAW/AliRawEquipmentV2.h
RAW/AliRawReaderRoot.cxx
RAW/AliRawVEquipment.h

index e9291c0..fc8e587 100644 (file)
@@ -95,17 +95,13 @@ AliRawEquipment::~AliRawEquipment()
 }
 
 //______________________________________________________________________________
-void AliRawEquipment::CloneRawData()
+void AliRawEquipment::CloneRawData(const AliRawData *rawData)
 {
-  // Load raw-data part of the object via the TRef
-  // flush the Tref and clone the raw data
+  // Clone the input raw data and
+  // flush the TRef
 
-  if (!fRawData) {
-    if (fRawDataRef.IsValid())
-      fRawData = (AliRawData*)fRawDataRef.GetObject();
-  }
   fRawDataRef = NULL;
-  if (fRawData) fRawData = (AliRawData*)fRawData->Clone();
+  if (rawData) rawData = (AliRawData*)rawData->Clone();
 }
 
 //______________________________________________________________________________
index a4c51a6..3f6a1b2 100644 (file)
@@ -52,7 +52,7 @@ public:
    virtual AliRawEquipmentHeader *GetEquipmentHeader();
    virtual AliRawData            *GetRawData();
 
-   virtual void                   CloneRawData();
+   virtual void                   CloneRawData(const AliRawData *rawData);
 
  private:
    AliRawEquipmentHeader *fEqpHdr;      // equipment header
index f03bfe1..8bd2aed 100644 (file)
@@ -117,12 +117,11 @@ AliRawData *AliRawEquipmentV2::NextRawData(AliRawDataArrayV2 *array)
 }
 
 //______________________________________________________________________________
-void AliRawEquipmentV2::CloneRawData()
+void AliRawEquipmentV2::CloneRawData(const AliRawData *rawData)
 {
-  // Load raw-data part of the object via the TRef
-  // flush the Tref and clone the raw data
+  // Clone the input raw data and
+  // flush the TRef
 
-  GetRawData();
   fRawDataRef = NULL;
-  if (fRawData) fRawData = (AliRawData*)fRawData->Clone();
+  if (rawData) fRawData = (AliRawData*)rawData->Clone();
 }
index cbd311f..9c7b79e 100644 (file)
@@ -51,7 +51,7 @@ public:
    void                           Reset();
    AliRawData                    *NextRawData(AliRawDataArrayV2 *array);
 
-   virtual void                   CloneRawData();
+   virtual void                   CloneRawData(const AliRawData *rawData);
 
 private:
    AliRawEquipmentHeader  fEqpHdr;      // equipment header
index 6cd6941..9b840f0 100644 (file)
@@ -669,16 +669,22 @@ AliRawReader* AliRawReaderRoot::CloneSingleEvent() const
   // access to the current raw data within
   // several threads (online event display/reco)
 
-  if (GetEvent()) {
+  if (fEvent) {
     // Root formatted raw data
-    AliRawVEvent *gdcRootEvent = (AliRawVEvent*) GetEvent()->Clone();
+    AliRawVEvent *gdcRootEvent = (AliRawVEvent*)fEvent->Clone();
     for (Int_t ldcCounter=0; ldcCounter < gdcRootEvent->GetNSubEvents(); ldcCounter++) {
       AliRawVEvent *ldcRootEvent = gdcRootEvent->GetSubEvent(ldcCounter);
+      AliRawVEvent *subEvent = fEvent->GetSubEvent(ldcCounter);
       for (Int_t eqCounter=0; eqCounter < ldcRootEvent->GetNEquipments(); eqCounter++) {
        AliRawVEquipment *equipment=ldcRootEvent->GetEquipment(eqCounter);
-       equipment->CloneRawData();
+       AliRawVEquipment *eq = subEvent->GetEquipment(eqCounter);
+       equipment->CloneRawData(eq->GetRawData());
       }
     }
+    // Reset original event and newly
+    // produced one
+    gdcRootEvent->GetSubEvent(-1);
+    fEvent->GetSubEvent(-1);
     return new AliRawReaderRoot(gdcRootEvent);
   }
   return NULL;
index 6cfad5f..d7c233a 100644 (file)
@@ -46,7 +46,7 @@ public:
    virtual AliRawEquipmentHeader *GetEquipmentHeader() = 0;
    virtual AliRawData            *GetRawData() = 0;
 
-   virtual void                   CloneRawData() = 0;
+   virtual void                   CloneRawData(const AliRawData *rawData) = 0;
 
 private: