]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - ANALYSIS/AliAnalysisDataContainer.h
Task now uses VV classes (ready for the case of flat)
[u/mrichter/AliRoot.git] / ANALYSIS / AliAnalysisDataContainer.h
index 5e583830c4e380ef96277c53edad6e89b9e280ab..4ac8007d98c62eb83ead7765b3bc78bc7dd8a4b6 100644 (file)
 #include "TString.h"
 #endif
 
+#ifndef ROOT_TStopwatch
+#include "TStopwatch.h"
+#endif
+
 class TClass;
+class TFile;
 class TObjArray;
 class TCollection;
 class AliAnalysisTask;
 class AliAnalysisDataWrapper;
-class AliESD;
+
+using std::ostream;
 
 class AliAnalysisDataContainer : public TNamed {
 
@@ -38,6 +44,13 @@ enum ENotifyMessage {
    kSaveData,
    kFileChange
 };   
+enum EAnalysisContainerFlags {
+   kPostEventLoop = BIT(14),
+   kSpecialOutput = BIT(15),
+   kRegisterDataset = BIT(16),
+   kExchangeData  = BIT(17),
+   kTouchedFlag   = BIT(18)
+};     
    AliAnalysisDataContainer();
    AliAnalysisDataContainer(const AliAnalysisDataContainer &cont);
    AliAnalysisDataContainer(const char *name, TClass *type);
@@ -48,16 +61,25 @@ enum ENotifyMessage {
    // Getters
    TObject                  *GetData() const      {return fData;}
    const char               *GetFileName() const  {return fFileName.Data();}
+   const char               *GetFolderName() const {return fFolderName.Data();}
+   TFile                    *GetFile() const      {return fFile;}
    TClass                   *GetType() const;
    AliAnalysisTask          *GetProducer() const  {return fProducer;}
    TObjArray                *GetConsumers() const {return fConsumers;}
    virtual void              GetEntry(Long64_t ientry);
    // Setters
+   void                      Reset()              {fData = 0; fDataReady = kFALSE; SetTouched(kFALSE);}
    void                      ResetDataReady()     {fDataReady = kFALSE;}
    virtual Bool_t            SetData(TObject *data, Option_t *option="");
    void                      SetDataOwned(Bool_t flag) {fOwnedData = flag;}
-   void                      SetFileName(const char *filename) {fFileName = filename;}
+   void                      SetExchange(Bool_t flag) {TObject::SetBit(kExchangeData,flag);}
+   void                      SetPostEventLoop(Bool_t flag=kTRUE) {TObject::SetBit(kPostEventLoop,flag);}
+   void                      SetSpecialOutput(Bool_t flag=kTRUE) {TObject::SetBit(kSpecialOutput,flag);}
+   void                      SetRegisterDataset(Bool_t flag=kTRUE) {TObject::SetBit(kRegisterDataset,flag);}
+   void                      SetFileName(const char *filename);
+   void                      SetFile(TFile *f) {fFile = f;}
    void                      SetProducer(AliAnalysisTask *prod, Int_t islot);
+   void                      SetTouched(Bool_t flag=kTRUE)       {TObject::SetBit(kTouchedFlag,flag);}
    void                      AddConsumer(AliAnalysisTask *cons, Int_t islot);
    void                      DeleteData();
    // Wrapping
@@ -65,6 +87,11 @@ enum ENotifyMessage {
    void                      ImportData(AliAnalysisDataWrapper *pack);
    // Container status checking
    Bool_t                    IsDataReady() const  {return fDataReady;}
+   Bool_t                    IsExchange() const      {return TObject::TestBit(kExchangeData);}
+   Bool_t                    IsPostEventLoop() const {return TObject::TestBit(kPostEventLoop);}
+   Bool_t                    IsSpecialOutput() const {return TObject::TestBit(kSpecialOutput);}
+   Bool_t                    IsRegisterDataset() const {return TObject::TestBit(kRegisterDataset);}
+   Bool_t                    IsTouched() const       {return TObject::TestBit(kTouchedFlag);}
    Bool_t                    IsOwnedData() const  {return fOwnedData;}
    Bool_t                    ClientsExecuted() const;
    Bool_t                    HasConsumers() const {return (fConsumers != 0);}
@@ -83,12 +110,14 @@ protected:
    Bool_t                    fDataReady;  // Flag that data is ready
    Bool_t                    fOwnedData;  // Flag data ownership
    TString                   fFileName;   // File storing the data
+   TString                   fFolderName; // Folder name in the output file
+   TFile                    *fFile;       //! Opened file
    TObject                  *fData;       // Contained data
    TClass                   *fType;       //! Type of contained data
    AliAnalysisTask          *fProducer;   // Analysis task to which the slot belongs
    TObjArray                *fConsumers;  // List of consumers of the data
    
-   ClassDef(AliAnalysisDataContainer,1)  // Class describing a data container for analysis
+   ClassDef(AliAnalysisDataContainer,2)  // Class describing a data container for analysis
 };
 
 //==============================================================================
@@ -100,11 +129,15 @@ protected:
 class AliAnalysisDataWrapper : public TNamed {
 
 public:
+
+enum EAnalysisWrapperFlags {
+   kDeleteData = BIT(14)
+};     
    AliAnalysisDataWrapper() : TNamed(), fData(NULL) {}
-   AliAnalysisDataWrapper(TObject *data) : TNamed(), fData(data) {}
+   AliAnalysisDataWrapper(TObject *data);
    AliAnalysisDataWrapper(const AliAnalysisDataWrapper &other) 
                         : TNamed(other), fData(other.fData) {}
-   virtual ~AliAnalysisDataWrapper() {}
+   virtual ~AliAnalysisDataWrapper();
    
    // Assignment
    AliAnalysisDataWrapper &operator=(const AliAnalysisDataWrapper &other);
@@ -112,6 +145,7 @@ public:
    TObject                  *Data() const {return fData;}
    // Merging
    virtual Long64_t          Merge(TCollection *list);
+   void                      SetDeleteData(Bool_t flag=kTRUE) {TObject::SetBit(kDeleteData,flag);}
 
 protected:
    TObject                  *fData;       // Wrapped data
@@ -119,4 +153,61 @@ protected:
    ClassDef(AliAnalysisDataWrapper, 1) // Data wrapper class for exchange via the net
 };
 
+//==============================================================================
+//   AliAnalysisFileDescriptor - A simple wrapper for data related to accessing
+//      an analysis input file.
+//==============================================================================
+class AliAnalysisFileDescriptor : public TObject {
+
+public:
+   AliAnalysisFileDescriptor();
+   AliAnalysisFileDescriptor(const TFile *file);
+   AliAnalysisFileDescriptor(const AliAnalysisFileDescriptor &other);
+   virtual ~AliAnalysisFileDescriptor();
+
+   // Assignment
+   AliAnalysisFileDescriptor &operator=(const AliAnalysisFileDescriptor &other);
+   
+   void         Done();
+   
+   const char  *GetGUID() const  {return fGUID;}
+   Int_t        GetImage() const {return fImage;}
+   const char  *GetLfn() const   {return fLfn;}
+   Int_t        GetNreplicas() const {return fNreplicas;}
+   Long64_t     GetOpenAt() const {return fOpenedAt;}
+   Double_t     GetOpenTime() const {return fOpenTime;}
+   const char  *GetPfn() const   {return fPfn;}
+   Long64_t     GetReadBytes() const {return fReadBytes;}
+   Long64_t     GetSize() const   {return fSize;}
+   const char  *GetSE() const     {return fSE;}
+   Double_t     GetThroughput() const {return fThroughput;}
+   Double_t     GetProcessingTime() const {return fProcessingTime;}
+   const char  *GetUrl() const    {return fUrl;}
+   Bool_t       IsArchive() const {return fIsArchive;}
+   virtual void Print(Option_t *option="") const;
+   virtual void SavePrimitive(std::ostream &out, Option_t *option = "");
+   void         SetOpenTime(Double_t time) {fOpenTime = time;}
+   
+
+protected:   
+   TString      fLfn;       // logical file name
+   TString      fGUID;      // GUID
+   TString      fUrl;       // url for the opened copy
+   TString      fPfn;       // physical file name
+   TString      fSE;        // Storage element
+   Bool_t       fIsArchive; // Archive flag
+   Int_t        fImage;     // Image number
+   Int_t        fNreplicas; // Number of replicas
+   Long64_t     fStartBytes;// Total number of read bytes at start
+   Long64_t     fReadBytes; // Number of bytes read
+   Long64_t     fSize;      // Size of the file in bytes
+   Long64_t     fOpenedAt;  // Absolute value for time when opened
+   Double_t     fOpenTime;  // Time elapsed to open file
+   Double_t     fProcessingTime; // Processing
+   Double_t     fThroughput; // Throughput
+   TStopwatch   fTimer;     //! Processing time
+   
+   ClassDef(AliAnalysisFileDescriptor,1)  // Class describing a a file processed in the analysis
+};
+
 #endif