1 #ifndef ALIDATALOADER_H
2 #define ALIDATALOADER_H
3 //__________________________________________
4 ////////////////////////////////////////////
6 // class AliDataLoader //
8 // Loader responsible for one data type //
9 // i.e. Hits, Kine, etc. //
10 // many objects type can be assciated //
11 // with one data type: storing object //
12 // (usually tree), task producing it, //
13 // Quality Assurance(QA), QA Task, and //
17 ////////////////////////////////////////////
22 #include <TDirectory.h>
29 class AliObjectLoader;
33 class AliDataLoader: public TNamed
37 AliDataLoader(const char* filename, const char* contname, const char* name, Option_t* opt = "t");
38 virtual ~AliDataLoader();
40 virtual Int_t SetEvent();
41 virtual Int_t GetEvent();
43 //shrtcuts method to basic data base loader 0
44 virtual Int_t Load(Option_t* opt="");
45 virtual void Unload();
46 virtual Int_t Reload();
47 virtual Int_t WriteData(Option_t* opt="");
48 virtual TTree* Tree() const;
50 virtual void MakeTree();
51 virtual Int_t OpenFile(Option_t* opt);
53 virtual void CloseFile();
56 const TString& GetFileName() const {return fFileName;}
57 TFile* GetFile() const {return fFile;}
58 TDirectory* GetDirectory() const {return fDirectory;}
59 const TString& GetFileOption() const {return fFileOption;}
60 const Int_t& GetCompressionLevel() const {return fCompressionLevel;}
62 Bool_t cd(){return (fDirectory)?fDirectory->cd():kFALSE;}
64 virtual void SetFileName(const TString& filename){fFileName = filename;}
65 virtual void SetFileOption(const Option_t* fileopt);
66 virtual void SetCompressionLevel(Int_t cl);
68 Int_t SetEventFolder(TFolder* eventfolder);//sets the event folder
69 Int_t SetFolder(TFolder* folder);//sets the data folder ??????
70 TFolder* GetEventFolder();
71 TFolder* GetFolder() const {return fFolder;}
73 // TObject* GetFromDirectory(const char *name){return (fDirectory)?fDirectory->Get(name):0x0;}
74 void SetFileNameSuffix(const TString& suffix);//adds the suffix before ".root",
75 //e.g. TPC.Digits.root -> TPC.DigitsMerged.root
76 //made on Jiri Chudoba demand
77 const TString SetFileOffset(const TString& fname);//adds the proper number before .root extension suffix
78 void SetDirName(TString& dirname);
80 void AddBaseLoader(AliBaseLoader* bl);
81 enum EStdBasicLoaders {kData = 0,kTask,kQA,kQATask};//standard basic loaders identifiers
83 AliBaseLoader* GetBaseLoader(const TString& name) const;
84 AliBaseLoader* GetBaseLoader(Int_t n) const;
85 AliObjectLoader* GetBaseDataLoader();
86 AliTaskLoader* GetBaseTaskLoader();
87 AliBaseLoader* GetBaseQALoader();
88 AliTaskLoader* GetBaseQATaskLoader();
90 void SetBaseDataLoader(AliBaseLoader* bl);
91 void SetBaseTaskLoader(AliTaskLoader* bl);
92 void SetBaseQALoader(AliBaseLoader* bl);
93 void SetBaseQATaskLoader(AliTaskLoader* bl);
95 Bool_t CheckReload();//checks if we have to reload given file
96 Bool_t IsFileWritable() const;
97 Bool_t IsFileOpen() const;
98 Bool_t IsOptionContrary(const TString& option) const;
103 Int_t GetDebug() const;
104 AliRunLoader* GetRunLoader();//gets the run-loader from event folder
108 TString fFileName; //name of the file
109 TFile* fFile; //! pointer to file
110 TDirectory* fDirectory; //!pointer to TDirectory
111 TString fFileOption; //!file option while opened
112 Int_t fCompressionLevel; //Compression Level of File
114 TObjArray* fBaseLoaders;//base loaders
115 Bool_t fHasTask;// flag if has a task
116 TString fTaskName;// name of the task
117 TTask* fParentalTask;//Parental task
119 TFolder* fEventFolder;//!event folder
120 TFolder* fFolder;//! folder with data
123 ClassDef(AliDataLoader,1)
127 //__________________________________________
128 ////////////////////////////////////////////
130 // class AliBaseLoader //
133 ////////////////////////////////////////////
136 class AliBaseLoader: public TNamed
140 AliBaseLoader(const TString& name, AliDataLoader* dl, Bool_t storeontop = kFALSE);
142 virtual ~AliBaseLoader(){};
144 virtual Int_t Load(Option_t* opt="");
145 virtual void Unload();
146 virtual Int_t Reload();
147 virtual Int_t WriteData(Option_t* opt="");
148 virtual void Clean();
149 virtual Int_t Post();
150 virtual Int_t Post(TObject* data);
151 virtual TObject* Get() const = 0;
152 Bool_t IsLoaded()const{return fIsLoaded;}
153 void SetDataLoader(AliDataLoader* dl){fDataLoader = dl;}
154 void SetEventFolder(TFolder* /*ef*/){;}
155 void SetDoNotReload(Bool_t flag){fDoNotReload = flag;}
156 Bool_t DoNotReload() const {return fDoNotReload;}
157 TDirectory* GetDirectory();//returns pointer to directory where data are stored.
158 TObject* GetFromDirectory(const char *name){return (GetDirectory())?GetDirectory()->Get(name):0x0;}
161 virtual Int_t AddToBoard(TObject* obj) = 0;//add to white board - board can be TTask or TFolder
162 virtual void RemoveFromBoard(TObject* obj) = 0;
164 AliDataLoader* GetDataLoader() const;
165 Int_t GetDebug() const;
167 Bool_t fIsLoaded; //! flag indicating if data are loaded
168 Bool_t fStoreInTopOfFile;// if true, data are stored in top of file ->Indicates fDoNotReload == kTRUE
171 Bool_t fDoNotReload; // if this flag is on object is not reloaded while GetEvent is called.
172 //Specially important for tasks. Task loops over events while producing data,
173 //and has a base loader which writes it to file every processed event.
174 //If this flag is not on, while taking next event, loader deletes task
175 // and tries to get new one from file
176 AliDataLoader* fDataLoader; //! pointer to Data Loader this Base Loader belongs to
178 ClassDef(AliBaseLoader,1)
181 //__________________________________________
182 ////////////////////////////////////////////
184 // class AliObjectLoader //
187 ////////////////////////////////////////////
189 class AliObjectLoader: public AliBaseLoader
193 AliObjectLoader(const TString& name, AliDataLoader* dl, Bool_t storeontop = kFALSE);
194 virtual ~AliObjectLoader(){};
195 TObject* Get() const;
198 TFolder* GetFolder() const;
199 Int_t AddToBoard(TObject* obj);
200 void RemoveFromBoard(TObject* obj);
202 ClassDef(AliObjectLoader,1)
206 //__________________________________________
207 ////////////////////////////////////////////
209 // class AliTreeLoader //
212 ////////////////////////////////////////////
214 class AliTreeLoader: public AliObjectLoader
218 AliTreeLoader(const TString& name, AliDataLoader* dl, Bool_t storeontop = kFALSE);
219 virtual ~AliTreeLoader(){};
221 virtual TTree* Tree() const {return dynamic_cast<TTree*>(Get());}
222 virtual void MakeTree();
223 virtual Int_t WriteData(Option_t* opt="");
225 ClassDef(AliTreeLoader,1)
228 //__________________________________________
229 ////////////////////////////////////////////
231 // class AliTaskLoader //
234 ////////////////////////////////////////////
236 class AliTaskLoader: public AliBaseLoader
239 AliTaskLoader():fParentalTask(0x0){};
240 AliTaskLoader(const TString& name, AliDataLoader* dl, TTask* parentaltask, Bool_t storeontop = kFALSE);
241 virtual ~AliTaskLoader(){};
243 TObject* Get() const;
244 virtual TTask* Task() const {return dynamic_cast<TTask*>(Get());}
247 Int_t AddToBoard(TObject* obj);
248 void RemoveFromBoard(TObject* obj);
249 TTask* GetParentalTask() const;
252 TTask* fParentalTask;
254 ClassDef(AliTaskLoader,1)