00001 #ifndef QUICK_ANA__OR_TOOL_H
00002 #define QUICK_ANA__OR_TOOL_H
00003
00005
00006 #include <QuickAna/Global.h>
00007
00008 #include <QuickAna/AnaTool.h>
00009 #include <AsgTools/AnaToolHandle.h>
00010 #include <AssociationUtils/ToolBox.h>
00011 #include <AssociationUtils/OverlapRemovalInit.h>
00012 #include <QuickAna/xAODInclude.h>
00013
00014
00015 namespace ORUtils
00016 {
00017 class IOverlapRemovalTool;
00018 class IOverlapTool;
00019 }
00020
00021 namespace ana
00022 {
00023
00037 class ORTool : public AnaTool
00038 {
00039
00040 ASG_TOOL_CLASS(ORTool, ana::IAnaTool)
00041
00042 public:
00043
00048 ORTool(const std::string& name);
00049
00051 virtual StatusCode
00052 setObjectType(ObjectType type, const std::string& workingPoint) override;
00053
00058 StatusCode initialize() override;
00059
00063 virtual AnalysisStep step() const override;
00064
00066 virtual unsigned inputTypes() const override;
00067
00069 virtual unsigned outputTypes() const override;
00070
00075 virtual StatusCode execute(IEventObjects& objects) override;
00076
00077 private:
00078
00079
00080
00081
00082
00084 ORUtils::ToolBox m_orToolBox;
00085
00087 ORUtils::ORFlags m_orFlags;
00088
00090 std::string m_anaSelectionName;
00091
00093
00094
00096
00097
00098 };
00099
00100 }
00101
00102 #endif