X-Git-Url: http://git.uio.no/git/?a=blobdiff_plain;f=STEER%2FAliCDBStorage.h;h=d8c3fcf558c93ab90032075affff043d01013c30;hb=b9d1a7e2fd1fffbe9f0d37c43424b0943c915d52;hp=bf6333827de312963dcaf1268f6944362946d328;hpb=620321242adc863f8edba964e55ab8ee5475abbd;p=u%2Fmrichter%2FAliRoot.git diff --git a/STEER/AliCDBStorage.h b/STEER/AliCDBStorage.h index bf6333827de..d8c3fcf558c 100644 --- a/STEER/AliCDBStorage.h +++ b/STEER/AliCDBStorage.h @@ -14,21 +14,27 @@ #include "AliCDBId.h" #include "AliCDBMetaData.h" +#include "AliCDBManager.h" #include +#include class AliCDBEntry; class AliCDBPath; +class AliCDBParam; +class TFile; class AliCDBStorage: public TObject { public: + AliCDBStorage(); void SetURI(const TString& uri) {fURI = uri;} const TString& GetURI() const {return fURI;} const TString& GetType() const {return fType;} const TString& GetBaseFolder() const {return fBaseFolder;} + AliCDBManager::DataType GetDataType() const; void ReadSelectionFromFile(const char *fileName); @@ -61,7 +67,7 @@ public: void PrintSelectionList(); AliCDBEntry* Get(const AliCDBId& query); - AliCDBEntry* Get(const AliCDBPath& path, Int_t runNumber, + AliCDBEntry* Get(const AliCDBPath& path, Int_t runNumber, Int_t version = -1, Int_t subVersion = -1); AliCDBEntry* Get(const AliCDBPath& path, const AliCDBRunRange& runRange, Int_t version = -1, Int_t subVersion = -1); @@ -72,31 +78,44 @@ public: TList* GetAll(const AliCDBPath& path, const AliCDBRunRange& runRange, Int_t version = -1, Int_t subVersion = -1); - Bool_t Put(TObject* object, AliCDBId& id, AliCDBMetaData* metaData); - Bool_t Put(AliCDBEntry* entry); + AliCDBId* GetId(const AliCDBId& query); + AliCDBId* GetId(const AliCDBPath& path, Int_t runNumber, + Int_t version = -1, Int_t subVersion = -1); + AliCDBId* GetId(const AliCDBPath& path, const AliCDBRunRange& runRange, + Int_t version = -1, Int_t subVersion = -1); + Bool_t Put(TObject* object, AliCDBId& id, AliCDBMetaData* metaData, + AliCDBManager::DataType type=AliCDBManager::kPrivate); + Bool_t Put(AliCDBEntry* entry, AliCDBManager::DataType type=AliCDBManager::kPrivate); virtual Bool_t IsReadOnly() const = 0; virtual Bool_t HasSubVersion() const = 0; virtual Bool_t Contains(const char* path) const = 0; + virtual Bool_t IdToFilename(const AliCDBId& id, TString& filename) const = 0; - void QueryCDB(Long64_t run, const char* pathFilter="*", + void QueryCDB(Int_t run, const char* pathFilter="*", Int_t version=-1, AliCDBMetaData *mdFilter=0); void PrintQueryCDB(); - TList* GetQueryCDBList() {return &fValidFileIds;} + TObjArray* GetQueryCDBList() {return &fValidFileIds;} + + virtual Int_t GetLatestVersion(const char* path, Int_t run)=0; + virtual Int_t GetLatestSubVersion(const char* path, Int_t run, Int_t version=-1)=0; protected: virtual ~AliCDBStorage(); void GetSelection(/*const*/ AliCDBId* id); virtual AliCDBEntry* GetEntry(const AliCDBId& query) = 0; + virtual AliCDBId* GetEntryId(const AliCDBId& query) = 0; virtual TList* GetEntries(const AliCDBId& query) = 0; virtual Bool_t PutEntry(AliCDBEntry* entry) = 0; virtual TList *GetIdListFromFile(const char* fileName)=0; virtual void QueryValidFiles() = 0; + void LoadTreeFromFile(AliCDBEntry* entry) const; + //void SetTreeToFile(AliCDBEntry* entry, TFile* file) const; - TList fValidFileIds; // list of Id's of the files valid for a given run (cached as fRun) - Long64_t fRun; // run number, used to manage list of valid files + TObjArray fValidFileIds; // list of Id's of the files valid for a given run (cached as fRun) + Int_t fRun; // run number, used to manage list of valid files AliCDBPath fPathFilter; // path filter, used to manage list of valid files Int_t fVersion; // version, used to manage list of valid files AliCDBMetaData* fMetaDataFilter; // metadata, used to manage list of valid files @@ -106,6 +125,10 @@ protected: TString fType; //! Local, Grid: base folder name - Dump: file name TString fBaseFolder; //! Local, Grid: base folder name - Dump: file name +private: + AliCDBStorage(const AliCDBStorage & source); + AliCDBStorage & operator=(const AliCDBStorage & source); + ClassDef(AliCDBStorage, 0); };