1 #ifndef ALIESDINPUTHANDLER_H
2 #define ALIESDINPUTHANDLER_H
3 /* Copyright(c) 1998-2007, ALICE Experiment at CERN, All rights reserved. *
4 * See cxx source for full Copyright notice */
8 //-------------------------------------------------------------------------
9 // ESD Input Handler realisation of the AliVEventHandler interface
10 // Author: Andreas Morsch, CERN
11 //-------------------------------------------------------------------------
13 #include "AliInputEventHandler.h"
14 #include "AliESDEvent.h"
23 class AliESDInputHandler : public AliInputEventHandler {
27 AliESDInputHandler(const char* name, const char* title);
28 virtual ~AliESDInputHandler();
29 virtual Bool_t Init(Option_t* /*opt*/) {return kTRUE;}
30 virtual Bool_t Init(TTree* tree, Option_t* opt);
31 virtual Bool_t BeginEvent(Long64_t entry);
32 virtual Bool_t Notify() { return AliVEventHandler::Notify(); };
33 virtual Bool_t Notify(const char* path);
34 virtual Bool_t FinishEvent();
35 void CheckSelectionMask();
36 AliESDEvent *GetEvent() const {return fEvent;}
37 Option_t *GetAnalysisType() const {return fAnalysisType;}
38 Option_t *GetDataType() const;
39 // Tag cut summary analysis
40 Int_t GetNEventAcceptedInFile();
41 Int_t GetNEventRejectedInFile();
42 Bool_t GetCutSummaryForChain(Int_t *aTotal, Int_t *aAccepted, Int_t *aRejected);
43 Int_t GetNFilesEmpty();
45 AliESDEvent *GetHLTEvent() const {return fHLTEvent;}
46 TTree *GetHLTTree() const {return fHLTTree;}
47 void SetReadHLT() {fUseHLT = kTRUE;}
49 AliESDfriend *GetESDfriend() const {return fFriend;}
50 AliESDpid *GetESDpid() const {return fESDpid;}
51 void SetESDpid(AliESDpid* pid) {fESDpid = pid;}
52 void SetReadFriends(Bool_t flag) {fReadFriends = flag;}
53 void SetFriendFileName(const char *fname) {fFriendFileName = fname;}
55 void SetReadTags() {fUseTags = kTRUE;}
56 AliRunTag *GetRunTag() const {return fRunTag;}
58 void SetMixingHandler(AliInputEventHandler* mixing)
59 {fMixingHandler = mixing;}
60 AliInputEventHandler* MixingHandler()
61 {return fMixingHandler;}
63 AliESDInputHandler(const AliESDInputHandler& handler);
64 AliESDInputHandler& operator=(const AliESDInputHandler& handler);
67 AliESDEvent *fEvent; //! Pointer to the event
68 AliESDfriend *fFriend; //! Pointer to the esd friend
69 AliESDpid *fESDpid; //! Pointer to PID information
70 Option_t *fAnalysisType; //! local, proof, grid
71 Int_t fNEvents; //! Number of events in the current tree
73 AliESDEvent *fHLTEvent; //! Pointer to the HLT Event (if present)
74 TTree *fHLTTree; //! Pointer to the HLT Event (if present)
75 Bool_t fUseHLT; // Flag to access HLT Events
76 // ESD Tag Cut Summary
77 TMap *fTagCutSumm; //! Tag cut summary map
78 // ESD Tags (optional)
79 Bool_t fUseTags; // Flag to use tags
80 TChain *fChainT; //! File with event tags
81 TTree *fTreeT; //! Tree of tags
82 AliRunTag *fRunTag; //! Pointer to the run tag
84 Bool_t fReadFriends; // Flag for friends reading
85 TString fFriendFileName;// Name of the file containing the frien tree (branch)
86 ClassDef(AliESDInputHandler, 6);