4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
7 /////////////////////////////////////////////////////////////////////
10 // access class to a DataBase in a dump storage (single file) //
12 /////////////////////////////////////////////////////////////////////
14 #include "AliCDBStorage.h"
15 #include "AliCDBManager.h"
20 class AliCDBDump: public AliCDBStorage {
21 friend class AliCDBDumpFactory;
25 virtual Bool_t IsReadOnly() const {return fReadOnly;};
26 virtual Bool_t HasSubVersion() const {return kFALSE;};
27 virtual Bool_t Contains(const char* path) const;
31 virtual AliCDBEntry* GetEntry(const AliCDBId& query);
32 virtual TList* GetEntries(const AliCDBId& query);
33 virtual Bool_t PutEntry(AliCDBEntry* entry);
34 virtual TList* GetIdListFromFile(const char* fileName);
38 AliCDBDump(const char* dbFile, Bool_t readOnly);
39 virtual ~AliCDBDump();
41 Bool_t KeyNameToId(const char* keyname, AliCDBRunRange& runRange,
42 Int_t& version, Int_t& subVersion);
43 Bool_t IdToKeyName(const AliCDBRunRange& runRange, Int_t version,
44 Int_t subVersion, TString& keyname);
46 Bool_t MkDir(const TString& dir);
49 Bool_t PrepareId(AliCDBId& id);
50 Bool_t GetId(const AliCDBId& query, AliCDBId& result);
52 virtual void QueryValidFiles();
54 void GetEntriesForLevel0(const AliCDBId& query, TList* result);
55 void GetEntriesForLevel1(const AliCDBId& query, TList* result);
57 TFile* fFile; // Dump file
58 Bool_t fReadOnly; // ReadOnly flag
60 ClassDef(AliCDBDump, 0);
63 /////////////////////////////////////////////////////////////////////
65 // class AliCDBDumpFactory //
67 /////////////////////////////////////////////////////////////////////
69 class AliCDBDumpFactory: public AliCDBStorageFactory {
73 virtual Bool_t Validate(const char* dbString);
74 virtual AliCDBParam* CreateParameter(const char* dbString);
77 virtual AliCDBStorage* Create(const AliCDBParam* param);
79 ClassDef(AliCDBDumpFactory, 0);
82 /////////////////////////////////////////////////////////////////////
84 // class AliCDBDumpParam //
86 /////////////////////////////////////////////////////////////////////
88 class AliCDBDumpParam: public AliCDBParam {
92 AliCDBDumpParam(const char* dbPath, Bool_t readOnly = kFALSE);
94 virtual ~AliCDBDumpParam();
96 const TString& GetPath() const {return fDBPath;};
97 Bool_t IsReadOnly() const {return fReadOnly;};
99 virtual AliCDBParam* CloneParam() const;
101 virtual ULong_t Hash() const;
102 virtual Bool_t IsEqual(const TObject* obj) const;
106 TString fDBPath; // Dump file path name
107 Bool_t fReadOnly; // ReadOnly flag
109 ClassDef(AliCDBDumpParam, 0);