New method to clone current raw-data event and create a single-event raw-reader....
authorcvetan <cvetan@f7af4fe6-9843-0410-8265-dc069ae4e863>
Fri, 4 Sep 2009 12:13:36 +0000 (12:13 +0000)
committercvetan <cvetan@f7af4fe6-9843-0410-8265-dc069ae4e863>
Fri, 4 Sep 2009 12:13:36 +0000 (12:13 +0000)
RAW/AliRawReader.h
RAW/AliRawReaderDate.cxx
RAW/AliRawReaderDate.h
RAW/AliRawReaderRoot.cxx
RAW/AliRawReaderRoot.h

index 85cdfa5..2eb8915 100644 (file)
@@ -168,6 +168,8 @@ class AliRawReader: public TObject {
 
     void             LoadTriggerClass(const char* name, Int_t index);
 
+    virtual AliRawReader* CloneSingleEvent() const { return NULL; }
+
   protected :
     virtual void     SelectEvents(Int_t type, ULong64_t triggerMask = 0, const char *triggerExpr = NULL);
     Bool_t           IsSelected() const;
index fa0ef4c..60dd68c 100644 (file)
@@ -129,8 +129,8 @@ AliRawReaderDate::~AliRawReaderDate()
 // destructor
 
 #ifdef ALI_DATE
+  if (fEvent) delete[] fEvent;
   if (fFile) {
-    delete[] fEvent;
     fclose(fFile);
   }
 #endif
@@ -636,3 +636,26 @@ Int_t AliRawReaderDate::CheckData() const
 #endif
   return 0;
 }
+
+AliRawReader* AliRawReaderDate::CloneSingleEvent() const
+{
+  // Clones the current event and
+  // creates raw-reader for the cloned event
+  // Can be used in order to make asynchronious
+  // access to the current raw data within
+  // several threads (online event display/reco)
+
+#ifdef ALI_DATE
+  if (fEvent) {
+    UInt_t evSize = fEvent->eventSize;
+    if (evSize) {
+      UChar_t *newEvent = new UChar_t[evSize];
+      memcpy(newEvent,fEvent,evSize);
+      return new AliRawReaderDate((void *)newEvent);
+    }
+  }
+#else
+  Fatal("AliRawReaderDate", "this class was compiled without DATE");
+#endif
+  return NULL;
+}
index 946180a..3a5011a 100644 (file)
@@ -52,6 +52,8 @@ class AliRawReaderDate: public AliRawReader {
 
     virtual Int_t    CheckData() const;
 
+    virtual AliRawReader* CloneSingleEvent() const;
+
   protected :
     FILE*            fFile;         // DATE file
     eventHeaderStruct* fEvent;      // raw data super event
index 4c39e32..6cd6941 100644 (file)
@@ -660,3 +660,26 @@ Int_t AliRawReaderRoot::CheckData() const
 
   return result;
 }
+
+AliRawReader* AliRawReaderRoot::CloneSingleEvent() const
+{
+  // Clones the current event and
+  // creates raw-reader for the cloned event
+  // Can be used in order to make asynchronious
+  // access to the current raw data within
+  // several threads (online event display/reco)
+
+  if (GetEvent()) {
+    // Root formatted raw data
+    AliRawVEvent *gdcRootEvent = (AliRawVEvent*) GetEvent()->Clone();
+    for (Int_t ldcCounter=0; ldcCounter < gdcRootEvent->GetNSubEvents(); ldcCounter++) {
+      AliRawVEvent *ldcRootEvent = gdcRootEvent->GetSubEvent(ldcCounter);
+      for (Int_t eqCounter=0; eqCounter < ldcRootEvent->GetNEquipments(); eqCounter++) {
+       AliRawVEquipment *equipment=ldcRootEvent->GetEquipment(eqCounter);
+       equipment->CloneRawData();
+      }
+    }
+    return new AliRawReaderRoot(gdcRootEvent);
+  }
+  return NULL;
+}
index d1b96e7..ca6e95a 100644 (file)
@@ -65,6 +65,8 @@ class AliRawReaderRoot: public AliRawReader {
 
     virtual const AliRawVEvent* GetEvent() const {return fEvent;}
 
+    virtual AliRawReader* CloneSingleEvent() const;
+
   protected :
     TFile*           fFile;         // raw data root file
     TBranch*         fBranch;       // branch of raw events