CMS 3D CMS Logo

ProductRegistryHelper.cc
Go to the documentation of this file.
1 /*----------------------------------------------------------------------
2 
3 ----------------------------------------------------------------------*/
4 
13 
14 #include <vector>
15 #include <typeindex>
16 
17 namespace edm {
19 
21 
22  namespace {
23  void throwProducesWithoutAbility(const char* runOrLumi, std::string const& productTypeName) {
25  << "Module declares it can produce a product of type \'" << productTypeName << "\'\nin a " << runOrLumi
26  << ", but does not have the ability to produce in " << runOrLumi << "s.\n"
27  << "You must add a template parameter of type Begin" << runOrLumi << "Producer\n"
28  << "or End" << runOrLumi << "Producer to the EDProducer or EDFilter base class\n"
29  << "of the module. Or you could remove the call to the function \'produces\'\n"
30  << "(Note legacy modules are not ever allowed to produce in Runs or Lumis)\n";
31  }
32  } // namespace
33 
34  void ProductRegistryHelper::addToRegistry(TypeLabelList::const_iterator const& iBegin,
35  TypeLabelList::const_iterator const& iEnd,
36  ModuleDescription const& iDesc,
37  ProductRegistry& iReg,
38  ProductRegistryHelper* iProd,
39  bool iIsListener) {
40  std::vector<std::string> missingDictionaries;
41  std::vector<std::string> producedTypes;
42  std::set<std::tuple<BranchType, std::type_index, std::string>> registeredProducts;
43 
44  for (TypeLabelList::const_iterator p = iBegin; p != iEnd; ++p) {
45  if (p->transition_ == Transition::BeginRun && not iProd->hasAbilityToProduceInBeginRuns()) {
46  throwProducesWithoutAbility("BeginRun", p->typeID_.userClassName());
47  } else if (p->transition_ == Transition::EndRun && not iProd->hasAbilityToProduceInEndRuns()) {
48  throwProducesWithoutAbility("EndRun", p->typeID_.userClassName());
49  } else if (p->transition_ == Transition::BeginLuminosityBlock && not iProd->hasAbilityToProduceInBeginLumis()) {
50  throwProducesWithoutAbility("BeginLuminosityBlock", p->typeID_.userClassName());
51  } else if (p->transition_ == Transition::EndLuminosityBlock && not iProd->hasAbilityToProduceInEndLumis()) {
52  throwProducesWithoutAbility("EndLuminosityBlock", p->typeID_.userClassName());
53  }
54  if (!checkDictionary(missingDictionaries, p->typeID_)) {
55  checkDictionaryOfWrappedType(missingDictionaries, p->typeID_);
56  producedTypes.emplace_back(p->typeID_.className());
57  continue;
58  }
59  auto branchType = convertToBranchType(p->transition_);
60  if (branchType != InEvent) {
61  std::tuple<BranchType, std::type_index, std::string> entry{
62  branchType, p->typeID_.typeInfo(), p->productInstanceName_};
63  if (registeredProducts.end() != registeredProducts.find(entry)) {
64  //ignore registration of items if in both begin and end transitions for now
65  // This is to work around ExternalLHEProducer
66  continue;
67  } else {
68  registeredProducts.insert(entry);
69  }
70  }
71 
72  TypeWithDict type(p->typeID_.typeInfo());
73  BranchDescription pdesc(branchType,
74  iDesc.moduleLabel(),
75  iDesc.processName(),
76  p->typeID_.userClassName(),
77  p->typeID_.friendlyClassName(),
78  p->productInstanceName_,
79  iDesc.moduleName(),
80  iDesc.parameterSetID(),
81  type,
82  true,
83  isEndTransition(p->transition_));
84  if (p->aliasType_ == TypeLabelItem::AliasType::kSwitchAlias) {
85  if (p->branchAlias_.empty()) {
87  << "Branch alias type has been set to SwitchAlias, but the alias content is empty.\n"
88  << "Please report this error to the FWCore developers";
89  }
90  pdesc.setSwitchAliasModuleLabel(p->branchAlias_);
91  }
92  setIsMergeable(pdesc);
93 
94  if (pdesc.transient()) {
95  if (!checkDictionary(missingDictionaries, pdesc.wrappedName(), pdesc.wrappedType())) {
96  // It is should be impossible to get here, because the only way to
97  // make it transient is in the line that causes the wrapped dictionary
98  // to be created. Just to be safe I leave this check here ...
99  producedTypes.emplace_back(pdesc.className());
100  continue;
101  }
102  } else {
103  // also check constituents of wrapped types if it is not transient
104  if (!checkClassDictionaries(missingDictionaries, pdesc.wrappedName(), pdesc.wrappedType())) {
105  producedTypes.emplace_back(pdesc.className());
106  continue;
107  }
108  }
109  if (!p->branchAlias_.empty())
110  pdesc.insertBranchAlias(p->branchAlias_);
111  iReg.addProduct(pdesc, iIsListener);
112  }
113 
114  if (!missingDictionaries.empty()) {
115  std::string context("Calling ProductRegistryHelper::addToRegistry, checking dictionaries for produced types");
116  throwMissingDictionariesException(missingDictionaries, context, producedTypes);
117  }
118  }
119 } // namespace edm
type
Definition: HCALResponse.h:21
void throwMissingDictionariesException(std::vector< std::string > &missingDictionaries, std::string const &context)
std::string const & processName() const
TypeLabelList const & typeLabelList() const
used by the fwk to register the list of products of this module
virtual bool hasAbilityToProduceInBeginLumis() const
std::string const & moduleName() const
virtual ~ProductRegistryHelper() noexcept(false)
static void addToRegistry(TypeLabelList::const_iterator const &iBegin, TypeLabelList::const_iterator const &iEnd, ModuleDescription const &iDesc, ProductRegistry &iReg, ProductRegistryHelper *iProd, bool iIsListener=false)
std::string const & moduleLabel() const
virtual bool hasAbilityToProduceInBeginRuns() const
constexpr bool isEndTransition(Transition iValue)
Definition: Transition.h:25
std::vector< TypeLabelItem > TypeLabelList
bool checkDictionary(std::vector< std::string > &missingDictionaries, TypeID const &typeID)
bool checkClassDictionaries(std::vector< std::string > &missingDictionaries, TypeID const &typeID)
#define noexcept
virtual bool hasAbilityToProduceInEndLumis() const
HLT enums.
ParameterSetID const & parameterSetID() const
bool checkDictionaryOfWrappedType(std::vector< std::string > &missingDictionaries, TypeID const &unwrappedTypeID)
void addProduct(BranchDescription const &productdesc, bool iFromListener=false)
void setIsMergeable(BranchDescription &)
constexpr BranchType convertToBranchType(Transition iValue)
Definition: Transition.h:15
virtual bool hasAbilityToProduceInEndRuns() const