ViewVC Help
View File | Revision Log | Show Annotations | Root Listing
root/cvsroot/UserCode/MitProd/TreeFiller/interface/BaseFiller.h
Revision: 1.11
Committed: Wed Jul 30 16:39:57 2008 UTC (16 years, 9 months ago) by loizides
Content type: text/plain
Branch: MAIN
CVS Tags: MITHEP_2_0_x
Changes since 1.10: +33 -8 lines
Log Message:
Example usage of ObjectService. Added ObjectService to all cfgs.

File Contents

# Content
1 //--------------------------------------------------------------------------------------------------
2 // $Id: BaseFiller.h,v 1.10 2008/07/30 08:39:50 loizides Exp $
3 //
4 // BaseFiller
5 //
6 // Base class to define the interface for a filler.
7 //
8 // Authors: C.Paus
9 //--------------------------------------------------------------------------------------------------
10
11 #ifndef TREEFILLER_BASEFILLER_H
12 #define TREEFILLER_BASEFILLER_H
13
14 #include "FWCore/Framework/interface/Event.h"
15 #include "FWCore/Framework/interface/Frameworkfwd.h"
16 #include "FWCore/ParameterSet/interface/ParameterSet.h"
17 #include "FWCore/MessageLogger/interface/MessageLogger.h"
18 #include "DataFormats/Common/interface/Handle.h"
19 #include "MitAna/DataUtil/interface/TreeWriter.h"
20 #include "MitProd/ObjectService/interface/ObjectService.h"
21 #include "MitProd/TreeFiller/interface/FillMitTree.h"
22 #include <TString.h>
23
24 namespace mithep
25 {
26 class BaseFiller
27 {
28 public:
29 BaseFiller(const edm::ParameterSet &cfg, const char *name, bool active=true);
30 virtual ~BaseFiller() {}
31
32 bool Active() const { return active_; }
33 virtual void BookDataBlock(TreeWriter &tws) = 0;
34 virtual void FillDataBlock(const edm::Event &e, const edm::EventSetup &es) = 0;
35 const std::string &Name() const { return name_; }
36 virtual void ResolveLinks(const edm::Event &e, const edm::EventSetup &es) {}
37
38 protected:
39 const edm::ParameterSet &Conf() const { return config_; }
40 void PrintErrorAndExit(const char *msg) const;
41 template <typename TYPE>
42 void GetProduct(const std::string name, edm::Handle<TYPE> &prod,
43 const edm::Event &event) const;
44 template <typename TYPE>
45 bool GetProductSafe(const std::string name, edm::Handle<TYPE> &prod,
46 const edm::Event &event) const;
47
48 ObjectService *OS() { return FillMitTree::os(); }
49
50 const std::string name_; //name of this filler
51 const edm::ParameterSet config_; //parameter set for this filler
52 const bool active_; //=1 if active
53 };
54 }
55
56 //--------------------------------------------------------------------------------------------------
57 template <typename TYPE>
58 inline void mithep::BaseFiller::GetProduct(const std::string edmname, edm::Handle<TYPE> &prod,
59 const edm::Event &event) const
60 {
61 // Try to access data collection from EDM file. We check if we really get just one
62 // product with the given name. If not we print an error and exit.
63
64 try {
65 event.getByLabel(edm::InputTag(edmname),prod);
66 if (!prod.isValid())
67 throw edm::Exception(edm::errors::Configuration, "BaseFiller::GetProduct()\n")
68 << "Cannot get collection with label " << edmname << std::endl;
69 } catch (...) {
70 edm::LogError("BaseFiller") << "Cannot get collection with label "
71 << edmname << std::endl;
72 PrintErrorAndExit(Form("Cannot get collection with label %s", edmname.c_str()));
73 }
74 }
75
76 //--------------------------------------------------------------------------------------------------
77 template <typename TYPE>
78 inline bool mithep::BaseFiller::GetProductSafe(const std::string edmname, edm::Handle<TYPE> &prod,
79 const edm::Event &event) const
80 {
81 // Try to safely access data collection from EDM file. We check if we really get just one
82 // product with the given name. If not, we return false.
83
84 try {
85 event.getByLabel(edm::InputTag(edmname),prod);
86 if (!prod.isValid())
87 return false;
88 } catch (...) {
89 return false;
90 }
91 return true;
92 }
93 #endif