class AliStack;
class AliRunDigitizer;
class AliCDBEntry;
-
+class AliCentralTrigger;
class AliRunLoader: public TNamed
{
AliRunLoader();
AliRunLoader(const char* topfoldername);
AliRunLoader(TFolder* topfolder);
- AliRunLoader(const AliRunLoader &rl);
- AliRunLoader & operator = (const AliRunLoader &rl)
- {rl.Copy(*this); return *this;}
virtual ~AliRunLoader();
void MakeTree(Option_t *option);
void MakeHeader();
+ void MakeTrigger();
void MakeStack();
Int_t LoadgAlice();
Int_t LoadHeader();
Int_t LoadKinematics(Option_t* option = "READ");
+ Int_t LoadTrigger(Option_t* option = "READ");
Int_t LoadTrackRefs(Option_t* option = "READ");
void UnloadHeader();
+ void UnloadTrigger();
void UnloadKinematics();
void UnloadgAlice();
void UnloadTrackRefs();
void SetTrackRefsFileName(const TString& fname){fTrackRefsDataLoader->SetFileName(fname);}
TTree* TreeE() const; //returns the tree from folder; shortcut method
+ TTree* TreeCT() const; //returns the tree from folder; shortcut method
AliHeader* GetHeader() const;
+ AliCentralTrigger* GetTrigger() const;
AliStack* Stack() const {return fStack;}
TTree* TreeTR() const; //returns the tree from folder; shortcut method
AliRun* GetAliRun()const;
+ Int_t GetRunNumber() const {return fRun;}
+ void SetRunNumber(Int_t run) {fRun=run;}
- Int_t WriteGeometry(Option_t* opt="");
Int_t WriteHeader(Option_t* opt="");
+ Int_t WriteTrigger(Option_t* opt="");
Int_t WriteAliRun(Option_t* opt="");
Int_t WriteKinematics(Option_t* opt="");
Int_t WriteTrackRefs(Option_t* opt="");
Int_t WriteRecPoints(Option_t* opt="");
Int_t WriteTracks(Option_t* opt="");
- Int_t LoadHits(Option_t* detectors = "all",Option_t* opt = "RAED");
- Int_t LoadSDigits(Option_t* detectors = "all",Option_t* opt = "RAED");
- Int_t LoadDigits(Option_t* detectors = "all",Option_t* opt = "RAED");
- Int_t LoadRecPoints(Option_t* detectors = "all",Option_t* opt = "RAED");
- Int_t LoadTracks(Option_t* detectors = "all",Option_t* opt = "RAED");
- Int_t LoadRecParticles(Option_t* detectors = "all",Option_t* opt = "RAED");
+ Int_t LoadHits(Option_t* detectors = "all",Option_t* opt = "READ");
+ Int_t LoadSDigits(Option_t* detectors = "all",Option_t* opt = "READ");
+ Int_t LoadDigits(Option_t* detectors = "all",Option_t* opt = "READ");
+ Int_t LoadRecPoints(Option_t* detectors = "all",Option_t* opt = "READ");
+ Int_t LoadTracks(Option_t* detectors = "all",Option_t* opt = "READ");
+ Int_t LoadRecParticles(Option_t* detectors = "all",Option_t* opt = "READ");
void UnloadHits(Option_t* detectors = "all");
void UnloadSDigits(Option_t* detectors = "all");
/***** Public S T A T I C Stuff *******/
/******************************************/
static AliRunLoader* GetRunLoader(const char* eventfoldername);
- static AliRunLoader* GetRunLoader(){return fgRunLoader;}
+ static AliRunLoader* Instance(){return fgRunLoader;}
static AliLoader* GetDetectorLoader(const char* detname, const char* eventfoldername);
static TTree* GetTreeH(const char* detname, Bool_t maketree, const char* eventfoldername);
static TTree* GetTreeS(const char* detname, Bool_t maketree, const char* eventfoldername);
static TTree* GetTreeT(const char* detname, Bool_t maketree, const char* eventfoldername);
static TTree* GetTreeP(const char* detname, Bool_t maketree, const char* eventfoldername);
-// static AliRunDigitizer* GetRunDigitizer();
// Tasks are supposed to be singletons, that is why following methods are static
static TTask* GetRunDigitizer(); //
static TTask* GetRunSDigitizer(); //
static TString GetRunLoaderName () {return fgkRunLoaderName;}
static TString GetHeaderContainerName () {return fgkHeaderContainerName;}
+ static TString GetTriggerContainerName () {return fgkTriggerContainerName;}
static TString GetKineContainerName () {return fgkKineContainerName;}
static TString GetTrackRefsContainerName () {return fgkTrackRefsContainerName;}
static TString GetHeaderBranchName () {return fgkHeaderBranchName;}
+ static TString GetTriggerBranchName () {return fgkTriggerBranchName;}
static TString GetKineBranchName () {return fgkKineBranchName;}
+ static TString GetTriggerFileName() { return fgkDefaultTriggerFileName; }
static TString GetGAliceName () {return fgkGAliceName;}
protected:
- /**********************************************/
- /************ PROTECTED ***************/
- /********* D A T A ************/
- /**********************************************/
+ void SetGAliceFile(TFile* gafile);//sets the pointer to gAlice file
+ Int_t OpenKineFile(Option_t* opt);
+ Int_t OpenTrackRefsFile(Option_t* opt);
+
+ Int_t OpenDataFile(const TString& filename,TFile*& file,TDirectory*& dir,Option_t* opt,Int_t cl);
+ void SetUnixDir(const TString& udirname);
+ const TString SetFileOffset(const TString& fname);//adds the proper number before .root
+ void SetDetectorAddresses();
- TObjArray *fLoaders; // List of Detectors
- TFolder *fEventFolder; //!top folder for this run
+ TObjArray *fLoaders; // List of Detectors
+ TFolder *fEventFolder; //!top folder for this run
- Int_t fCurrentEvent;//!Number of current event
+ Int_t fRun; //! Current run number
+ Int_t fCurrentEvent;//!Number of current event
- TFile *fGAFile;//! pointer to main file with AliRun and Run Loader -> galice.root
- AliHeader *fHeader;//! pointer to header
- AliStack *fStack; //! pointer to stack
+ TFile *fGAFile;//! pointer to main file with AliRun and Run Loader -> galice.root
+ AliHeader *fHeader;//! pointer to header
+ AliStack *fStack; //! pointer to stack
+ AliCentralTrigger *fCTrigger; //! pointer to CEntral Trigger Processor
- AliDataLoader *fKineDataLoader;// kinematics data loader
- AliDataLoader *fTrackRefsDataLoader;//track reference data loader
+ AliDataLoader *fKineDataLoader;// kinematics data loader
+ AliDataLoader *fTrackRefsDataLoader;//track reference data loader
- Int_t fNEventsPerFile; //defines number of events stored per one file
- TString fUnixDirName; //! name of unix path to directory that contains event
+ Int_t fNEventsPerFile; //defines number of events stored per one file
+ TString fUnixDirName; //! name of unix path to directory that contains event
static const TString fgkDefaultKineFileName;//default file name with kinamatics
static const TString fgkDefaultTrackRefsFileName;//default file name with kinamatics
+ static const TString fgkDefaultTriggerFileName;//default file name with trigger
-
- /*********************************************/
- /************ PROTECTED **************/
- /********* M E T H O D S ***********/
- /*********************************************/
-
- void SetGAliceFile(TFile* gafile);//sets the pointer to gAlice file
- Int_t OpenKineFile(Option_t* opt);
- Int_t OpenTrackRefsFile(Option_t* opt);
-
- Int_t OpenDataFile(const TString& filename,TFile*& file,TDirectory*& dir,Option_t* opt,Int_t cl);
- void SetUnixDir(const TString& udirname);
- const TString SetFileOffset(const TString& fname);//adds the proper number before .root
- void SetDetectorAddresses();
private:
+ AliRunLoader(const AliRunLoader &r); //Not implemented
+ AliRunLoader & operator = (const AliRunLoader &); //Not implemented
void GetListOfDetectors(const char * namelist,TObjArray& pointerarray) const;
-
void CleanHeader(){Clean(fgkHeaderContainerName);}
+ void CleanTrigger(){Clean(fgkTriggerContainerName);}
void Clean(const TString& name);
-
Int_t SetEvent();
- static AliRunLoader* fgRunLoader; //pointer to the AliRunLoader instance
-
-private:
- void Copy(TObject &arun) const;
+ static AliRunLoader* fgRunLoader; //pointer to the AliRunLoader instance
static const TString fgkRunLoaderName; //default name of the run loader
static const TString fgkHeaderContainerName; //default name of the kinematics container (TREE) name - TreeE
+ static const TString fgkTriggerContainerName; //default name of the trigger container (TREE) name - TreeCT
static const TString fgkKineContainerName; //default name of the kinematics container (TREE) name - TreeK
static const TString fgkTrackRefsContainerName; //default name of the track references container (TREE) name - TreeTR
static const TString fgkHeaderBranchName; //default name of the branch containing the header
+ static const TString fgkTriggerBranchName; //default name of the branch containing the trigger
static const TString fgkKineBranchName; //default name of the branch with kinematics
static const TString fgkGAliceName; //default name for gAlice file
- ClassDef(AliRunLoader,1)
+ ClassDef(AliRunLoader,2)
};
#endif