CMS 3D CMS Logo

List of all members | Classes | Public Member Functions | Private Types | Private Member Functions | Private Attributes
BareRootProductGetter Class Reference

#include <FWCore/FWLite/interface/BareRootProductGetter.h>

Inheritance diagram for BareRootProductGetter:
edm::EDProductGetter

Classes

struct  Buffer
 

Public Member Functions

 BareRootProductGetter ()
 
edm::WrapperBase const * getIt (edm::ProductID const &) const override
 
edm::WrapperBase const * getThinnedProduct (edm::ProductID const &, unsigned int &key) const override
 
void getThinnedProducts (edm::ProductID const &, std::vector< edm::WrapperBase const * > &foundContainers, std::vector< unsigned int > &keys) const override
 
 ~BareRootProductGetter () override
 
- Public Member Functions inherited from edm::EDProductGetter
 EDProductGetter ()
 
 EDProductGetter (EDProductGetter const &)=delete
 
EDProductGetter const & operator= (EDProductGetter const &)=delete
 
unsigned int transitionIndex () const
 
virtual ~EDProductGetter ()
 

Private Types

typedef std::map< edm::BranchID, BufferIdToBuffers
 

Private Member Functions

 BareRootProductGetter (BareRootProductGetter const &)=delete
 
BuffercreateNewBuffer (edm::BranchID const &) const
 
edm::WrapperBase const * getIt (edm::BranchID const &, Long_t eventEntry) const
 
edm::ThinnedAssociation const * getThinnedAssociation (edm::BranchID const &branchID, Long_t eventEntry) const
 
BareRootProductGetter const & operator= (BareRootProductGetter const &)=delete
 
unsigned int transitionIndex_ () const override
 

Private Attributes

fwlite::BranchMapReader branchMap_
 
IdToBuffers idToBuffers_
 

Additional Inherited Members

- Static Public Member Functions inherited from edm::EDProductGetter
static void assignEDProductGetter (EDProductGetter const *&)
 
static EDProductGetter const * switchProductGetter (EDProductGetter const *)
 These can only be used internally by the framework. More...
 

Detailed Description

Description: <one line="" class="" summary>="">

Usage: <usage>

Definition at line 43 of file BareRootProductGetter.h.

Member Typedef Documentation

◆ IdToBuffers

Definition at line 104 of file BareRootProductGetter.h.

Constructor & Destructor Documentation

◆ BareRootProductGetter() [1/2]

BareRootProductGetter::BareRootProductGetter ( )

Definition at line 44 of file BareRootProductGetter.cc.

44 {}

◆ ~BareRootProductGetter()

BareRootProductGetter::~BareRootProductGetter ( )
override

Definition at line 50 of file BareRootProductGetter.cc.

50 {}

◆ BareRootProductGetter() [2/2]

BareRootProductGetter::BareRootProductGetter ( BareRootProductGetter const &  )
privatedelete

Member Function Documentation

◆ createNewBuffer()

BareRootProductGetter::Buffer * BareRootProductGetter::createNewBuffer ( edm::BranchID const &  branchID) const
private

Definition at line 278 of file BareRootProductGetter.cc.

278  {
279  //find the branch
280  edm::BranchDescription const& bdesc = branchMap_.branchIDToBranch(branchID);
281 
282  TBranch* branch = branchMap_.getEventTree()->GetBranch(bdesc.branchName().c_str());
283  if (nullptr == branch) {
284  //we do not thrown on missing branches since 'getIt' should not throw under that condition
285  return nullptr;
286  }
287  //find the class type
290  if (!bool(classType)) {
291  throw cms::Exception("MissingDictionary") << "could not find dictionary for type '" << fullName << "'"
292  << "\n Please make sure all the necessary libraries are available.";
293  return nullptr;
294  }
295 
296  TClass* rootClassType = TClass::GetClass(classType.typeInfo());
297  if (nullptr == rootClassType) {
298  throw cms::Exception("MissingRootDictionary") << "could not find a ROOT dictionary for type '" << fullName << "'"
299  << "\n Please make sure all the necessary libraries are available.";
300  return nullptr;
301  }
302  void* address = rootClassType->New();
303 
304  static TClass const* edproductTClass = TClass::GetClass(typeid(edm::WrapperBase));
305  edm::WrapperBase const* prod =
306  static_cast<edm::WrapperBase const*>(rootClassType->DynamicCast(edproductTClass, address, true));
307  if (nullptr == prod) {
308  throw cms::Exception("FailedConversion") << "failed to convert a '" << fullName << "' to a edm::WrapperBase."
309  << "Please contact developers since something is very wrong.";
310  }
311 
312  //connect the instance to the branch
313  //void* address = wrapperObj.Address();
314  Buffer b(prod, branch, address, rootClassType);
315  idToBuffers_[branchID] = std::move(b);
316 
317  //As of 5.13 ROOT expects the memory address held by the pointer passed to
318  // SetAddress to be valid forever
319  address = &(idToBuffers_[branchID].address_);
320  branch->SetAddress(address);
321 
322  return &(idToBuffers_[branchID]);
323 }

References b, MicroEventContent_cff::branch, fwlite::BranchMapReader::branchIDToBranch(), branchMap_, edm::BranchDescription::branchName(), edm::TypeWithDict::byName(), edm::BranchDescription::className(), Exception, newFWLiteAna::fullName, fwlite::BranchMapReader::getEventTree(), idToBuffers_, eostools::move(), dumpMFGeometry_cfg::prod, AlCaHLTBitMon_QueryRunRegistry::string, and edm::wrappedClassName().

Referenced by getIt().

◆ getIt() [1/2]

edm::WrapperBase const * BareRootProductGetter::getIt ( edm::BranchID const &  branchID,
Long_t  eventEntry 
) const
private

Definition at line 104 of file BareRootProductGetter.cc.

104  {
105  Buffer* buffer = nullptr;
106  IdToBuffers::iterator itBuffer = idToBuffers_.find(branchID);
107 
108  // std::cout << "Buffers" << std::endl;
109  if (itBuffer == idToBuffers_.end()) {
110  buffer = createNewBuffer(branchID);
111  // std::cout << "buffer " << buffer << std::endl;
112  if (nullptr == buffer) {
113  return nullptr;
114  }
115  } else {
116  buffer = &(itBuffer->second);
117  }
118  if (nullptr == buffer) {
119  throw cms::Exception("NullBuffer") << "Found a null buffer which is supposed to hold the data item."
120  << "\n Please contact developers since this message should not happen.";
121  }
122  if (nullptr == buffer->branch_) {
123  throw cms::Exception("NullBranch") << "The TBranch which should hold the data item is null."
124  << "\n Please contact the developers since this message should not happen.";
125  }
126  if (buffer->eventEntry_ != eventEntry) {
127  //NOTE: Need to reset address because user could have set the address themselves
128  //std::cout << "new event" << std::endl;
129 
130  //ROOT WORKAROUND: Create new objects so any internal data cache will get cleared
131  void* address = buffer->class_->New();
132 
133  static TClass const* edproductTClass = TClass::GetClass(typeid(edm::WrapperBase));
134  edm::WrapperBase const* prod =
135  static_cast<edm::WrapperBase const*>(buffer->class_->DynamicCast(edproductTClass, address, true));
136 
137  if (nullptr == prod) {
138  cms::Exception("FailedConversion") << "failed to convert a '" << buffer->class_->GetName()
139  << "' to a edm::WrapperBase."
140  << "Please contact developers since something is very wrong.";
141  }
142  buffer->address_ = address;
143  buffer->product_ = std::shared_ptr<edm::WrapperBase const>(prod);
144  //END WORKAROUND
145 
146  address = &(buffer->address_);
147  buffer->branch_->SetAddress(address);
148 
149  buffer->branch_->GetEntry(eventEntry);
150  buffer->eventEntry_ = eventEntry;
151  }
152  if (!buffer->product_) {
153  throw cms::Exception("BranchGetEntryFailed")
154  << "Calling GetEntry with index " << eventEntry << "for branch " << buffer->branch_->GetName() << " failed.";
155  }
156 
157  return buffer->product_.get();
158 }

References edmScanValgrind::buffer, createNewBuffer(), Exception, idToBuffers_, and dumpMFGeometry_cfg::prod.

◆ getIt() [2/2]

edm::WrapperBase const * BareRootProductGetter::getIt ( edm::ProductID const &  pid) const
overridevirtual

Implements edm::EDProductGetter.

Definition at line 70 of file BareRootProductGetter.cc.

70  {
71  // std::cout << "getIt called " << pid << std::endl;
72  TFile* currentFile = dynamic_cast<TFile*>(gROOT->GetListOfFiles()->Last());
73  if (nullptr == currentFile) {
74  throw cms::Exception("FileNotFound") << "unable to find the TFile '" << gROOT->GetListOfFiles()->Last() << "'\n"
75  << "retrieved by calling 'gROOT->GetListOfFiles()->Last()'\n"
76  << "Please check the list of files.";
77  }
78  if (branchMap_.updateFile(currentFile)) {
79  idToBuffers_.clear();
80  }
81  TTree* eventTree = branchMap_.getEventTree();
82  // std::cout << "eventTree " << eventTree << std::endl;
83  if (nullptr == eventTree) {
84  throw cms::Exception("NoEventsTree")
85  << "unable to find the TTree '" << edm::poolNames::eventTreeName() << "' in the last open file, \n"
86  << "file: '" << branchMap_.getFile()->GetName()
87  << "'\n Please check that the file is a standard CMS ROOT format.\n"
88  << "If the above is not the file you expect then please open your data file after all other files.";
89  }
90  Long_t eventEntry = eventTree->GetReadEntry();
91  // std::cout << "eventEntry " << eventEntry << std::endl;
92  branchMap_.updateEvent(eventEntry);
93  if (eventEntry < 0) {
94  throw cms::Exception("GetEntryNotCalled")
95  << "please call GetEntry for the 'Events' TTree for each event in order to make edm::Ref's work."
96  << "\n Also be sure to call 'SetAddress' for all Branches after calling the GetEntry.";
97  }
98 
100 
101  return getIt(branchID, eventEntry);
102 }

References branchMap_, edm::poolNames::eventTreeName(), Exception, fwlite::BranchMapReader::getEventTree(), fwlite::BranchMapReader::getFile(), idToBuffers_, fwlite::BranchMapReader::productToBranchID(), fwlite::BranchMapReader::updateEvent(), and fwlite::BranchMapReader::updateFile().

Referenced by getThinnedAssociation(), getThinnedProduct(), and getThinnedProducts().

◆ getThinnedAssociation()

edm::ThinnedAssociation const * BareRootProductGetter::getThinnedAssociation ( edm::BranchID const &  branchID,
Long_t  eventEntry 
) const
private

Definition at line 325 of file BareRootProductGetter.cc.

326  {
327  edm::WrapperBase const* wrapperBase = getIt(branchID, eventEntry);
328  if (wrapperBase == nullptr) {
330  << "BareRootProductGetter::getThinnedAssociation, product ThinnedAssociation not found.\n";
331  }
332  if (!(typeid(edm::ThinnedAssociation) == wrapperBase->dynamicTypeInfo())) {
334  << "BareRootProductGetter::getThinnedAssociation, product has wrong type, not a ThinnedAssociation.\n";
335  }
337  static_cast<edm::Wrapper<edm::ThinnedAssociation> const*>(wrapperBase);
338 
339  edm::ThinnedAssociation const* thinnedAssociation = wrapper->product();
340  return thinnedAssociation;
341 }

References watchdog::const, edm::WrapperBase::dynamicTypeInfo(), Exception, getIt(), edm::errors::LogicError, and wrapper.

Referenced by getThinnedProduct(), and getThinnedProducts().

◆ getThinnedProduct()

edm::WrapperBase const * BareRootProductGetter::getThinnedProduct ( edm::ProductID const &  pid,
unsigned int &  key 
) const
overridevirtual

Implements edm::EDProductGetter.

Definition at line 160 of file BareRootProductGetter.cc.

160  {
161  Long_t eventEntry = branchMap_.getEventTree()->GetReadEntry();
163  if (!parent.isValid())
164  return nullptr;
165  edm::ThinnedAssociationsHelper const& thinnedAssociationsHelper = branchMap_.thinnedAssociationsHelper();
166 
167  // Loop over thinned containers which were made by selecting elements from the parent container
168  for (auto associatedBranches = thinnedAssociationsHelper.parentBegin(parent),
169  iEnd = thinnedAssociationsHelper.parentEnd(parent);
170  associatedBranches != iEnd;
171  ++associatedBranches) {
172  edm::ThinnedAssociation const* thinnedAssociation =
173  getThinnedAssociation(associatedBranches->association(), eventEntry);
174  if (thinnedAssociation == nullptr)
175  continue;
176 
177  if (associatedBranches->parent() != branchMap_.productToBranchID(thinnedAssociation->parentCollectionID())) {
178  continue;
179  }
180 
181  unsigned int thinnedIndex = 0;
182  // Does this thinned container have the element referenced by key?
183  // If yes, thinnedIndex is set to point to it in the thinned container
184  if (!thinnedAssociation->hasParentIndex(key, thinnedIndex)) {
185  continue;
186  }
187  // Get the thinned container and return a pointer if we can find it
188  edm::ProductID const& thinnedCollectionPID = thinnedAssociation->thinnedCollectionID();
189  edm::WrapperBase const* thinnedCollection = getIt(thinnedCollectionPID);
190  if (thinnedCollection == nullptr) {
191  // Thinned container is not found, try looking recursively in thinned containers
192  // which were made by selecting elements from this thinned container.
193  edm::WrapperBase const* thinnedFromRecursiveCall = getThinnedProduct(thinnedCollectionPID, thinnedIndex);
194  if (thinnedFromRecursiveCall != nullptr) {
195  key = thinnedIndex;
196  return thinnedFromRecursiveCall;
197  } else {
198  continue;
199  }
200  }
201  key = thinnedIndex;
202  return thinnedCollection;
203  }
204  return nullptr;
205 }

References branchMap_, fwlite::BranchMapReader::getEventTree(), getIt(), getThinnedAssociation(), edm::ThinnedAssociation::hasParentIndex(), crabWrapper::key, class-composition::parent, edm::ThinnedAssociationsHelper::parentBegin(), edm::ThinnedAssociation::parentCollectionID(), edm::ThinnedAssociationsHelper::parentEnd(), fwlite::BranchMapReader::productToBranchID(), fwlite::BranchMapReader::thinnedAssociationsHelper(), and edm::ThinnedAssociation::thinnedCollectionID().

◆ getThinnedProducts()

void BareRootProductGetter::getThinnedProducts ( edm::ProductID const &  pid,
std::vector< edm::WrapperBase const * > &  foundContainers,
std::vector< unsigned int > &  keys 
) const
overridevirtual

Implements edm::EDProductGetter.

Definition at line 207 of file BareRootProductGetter.cc.

209  {
210  Long_t eventEntry = branchMap_.getEventTree()->GetReadEntry();
212  if (!parent.isValid())
213  return;
214  edm::ThinnedAssociationsHelper const& thinnedAssociationsHelper = branchMap_.thinnedAssociationsHelper();
215 
216  // Loop over thinned containers which were made by selecting elements from the parent container
217  for (auto associatedBranches = thinnedAssociationsHelper.parentBegin(parent),
218  iEnd = thinnedAssociationsHelper.parentEnd(parent);
219  associatedBranches != iEnd;
220  ++associatedBranches) {
221  edm::ThinnedAssociation const* thinnedAssociation =
222  getThinnedAssociation(associatedBranches->association(), eventEntry);
223  if (thinnedAssociation == nullptr)
224  continue;
225 
226  if (associatedBranches->parent() != branchMap_.productToBranchID(thinnedAssociation->parentCollectionID())) {
227  continue;
228  }
229 
230  unsigned int nKeys = keys.size();
231  unsigned int doNotLookForThisIndex = std::numeric_limits<unsigned int>::max();
232  std::vector<unsigned int> thinnedIndexes(nKeys, doNotLookForThisIndex);
233  bool hasAny = false;
234  for (unsigned k = 0; k < nKeys; ++k) {
235  // Already found this one
236  if (foundContainers[k] != nullptr)
237  continue;
238  // Already know this one is not in this thinned container
239  if (keys[k] == doNotLookForThisIndex)
240  continue;
241  // Does the thinned container hold the entry of interest?
242  // Modifies thinnedIndexes[k] only if it returns true and
243  // sets it to the index in the thinned collection.
244  if (thinnedAssociation->hasParentIndex(keys[k], thinnedIndexes[k])) {
245  hasAny = true;
246  }
247  }
248  if (!hasAny) {
249  continue;
250  }
251  // Get the thinned container and set the pointers and indexes into
252  // it (if we can find it)
253  edm::ProductID thinnedCollectionPID = thinnedAssociation->thinnedCollectionID();
254  edm::WrapperBase const* thinnedCollection = getIt(thinnedCollectionPID);
255 
256  if (thinnedCollection == nullptr) {
257  // Thinned container is not found, try looking recursively in thinned containers
258  // which were made by selecting elements from this thinned container.
259  getThinnedProducts(thinnedCollectionPID, foundContainers, thinnedIndexes);
260  for (unsigned k = 0; k < nKeys; ++k) {
261  if (foundContainers[k] == nullptr)
262  continue;
263  if (thinnedIndexes[k] == doNotLookForThisIndex)
264  continue;
265  keys[k] = thinnedIndexes[k];
266  }
267  } else {
268  for (unsigned k = 0; k < nKeys; ++k) {
269  if (thinnedIndexes[k] == doNotLookForThisIndex)
270  continue;
271  keys[k] = thinnedIndexes[k];
272  foundContainers[k] = thinnedCollection;
273  }
274  }
275  }
276 }

References branchMap_, fwlite::BranchMapReader::getEventTree(), getIt(), getThinnedAssociation(), edm::ThinnedAssociation::hasParentIndex(), dqmdumpme::k, relativeConstraints::keys, SiStripPI::max, class-composition::parent, edm::ThinnedAssociationsHelper::parentBegin(), edm::ThinnedAssociation::parentCollectionID(), edm::ThinnedAssociationsHelper::parentEnd(), fwlite::BranchMapReader::productToBranchID(), fwlite::BranchMapReader::thinnedAssociationsHelper(), and edm::ThinnedAssociation::thinnedCollectionID().

◆ operator=()

BareRootProductGetter const& BareRootProductGetter::operator= ( BareRootProductGetter const &  )
privatedelete

◆ transitionIndex_()

unsigned int BareRootProductGetter::transitionIndex_ ( ) const
inlineoverrideprivatevirtual

Implements edm::EDProductGetter.

Definition at line 79 of file BareRootProductGetter.h.

79 { return 0u; }

Member Data Documentation

◆ branchMap_

fwlite::BranchMapReader BareRootProductGetter::branchMap_
mutableprivate

◆ idToBuffers_

IdToBuffers BareRootProductGetter::idToBuffers_
mutableprivate

Definition at line 105 of file BareRootProductGetter.h.

Referenced by createNewBuffer(), and getIt().

edm::TypeWithDict::byName
static TypeWithDict byName(std::string const &name)
Definition: TypeWithDict.cc:74
edm::poolNames::eventTreeName
std::string const & eventTreeName()
Definition: BranchType.cc:218
BareRootProductGetter::getThinnedProducts
void getThinnedProducts(edm::ProductID const &, std::vector< edm::WrapperBase const * > &foundContainers, std::vector< unsigned int > &keys) const override
Definition: BareRootProductGetter.cc:207
edm::errors::LogicError
Definition: EDMException.h:37
MicroEventContent_cff.branch
branch
Definition: MicroEventContent_cff.py:152
edm::ThinnedAssociation
Definition: ThinnedAssociation.h:14
BareRootProductGetter::getThinnedProduct
edm::WrapperBase const * getThinnedProduct(edm::ProductID const &, unsigned int &key) const override
Definition: BareRootProductGetter.cc:160
edm::ThinnedAssociationsHelper::parentEnd
std::vector< ThinnedAssociationBranches >::const_iterator parentEnd(BranchID const &) const
Definition: ThinnedAssociationsHelper.cc:36
fwlite::BranchMapReader::branchIDToBranch
const edm::BranchDescription & branchIDToBranch(const edm::BranchID &bid) const
Definition: BranchMapReader.h:86
relativeConstraints.keys
keys
Definition: relativeConstraints.py:89
wrapper
static HepMC::HEPEVT_Wrapper wrapper
Definition: BeamHaloProducer.cc:47
BareRootProductGetter::idToBuffers_
IdToBuffers idToBuffers_
Definition: BareRootProductGetter.h:105
fwlite::BranchMapReader::productToBranchID
edm::BranchID productToBranchID(const edm::ProductID &pid)
Definition: BranchMapReader.h:84
fwlite::BranchMapReader::getEventTree
TTree const * getEventTree() const
Definition: BranchMapReader.h:94
watchdog.const
const
Definition: watchdog.py:83
edm::Wrapper
Definition: Product.h:10
fwlite::BranchMapReader::updateEvent
bool updateEvent(Long_t eventEntry)
Definition: BranchMapReader.cc:604
edmScanValgrind.buffer
buffer
Definition: edmScanValgrind.py:171
fwlite::BranchMapReader::updateFile
bool updateFile(TFile *file)
Definition: BranchMapReader.cc:610
edm::BranchID
Definition: BranchID.h:14
dumpMFGeometry_cfg.prod
prod
Definition: dumpMFGeometry_cfg.py:24
BareRootProductGetter::getThinnedAssociation
edm::ThinnedAssociation const * getThinnedAssociation(edm::BranchID const &branchID, Long_t eventEntry) const
Definition: BareRootProductGetter.cc:325
BareRootProductGetter::branchMap_
fwlite::BranchMapReader branchMap_
Definition: BareRootProductGetter.h:106
fwlite::BranchMapReader::thinnedAssociationsHelper
const edm::ThinnedAssociationsHelper & thinnedAssociationsHelper() const
Definition: BranchMapReader.h:109
dqmdumpme.k
k
Definition: dqmdumpme.py:60
b
double b
Definition: hdecay.h:118
edm::ThinnedAssociation::thinnedCollectionID
ProductID const & thinnedCollectionID() const
Definition: ThinnedAssociation.h:19
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
newFWLiteAna.fullName
fullName
Definition: newFWLiteAna.py:122
edm::WrapperBase::dynamicTypeInfo
std::type_info const & dynamicTypeInfo() const
Definition: WrapperBase.h:42
edm::ThinnedAssociationsHelper
Definition: ThinnedAssociationsHelper.h:35
edm::TypeWithDict
Definition: TypeWithDict.h:38
BareRootProductGetter::getIt
edm::WrapperBase const * getIt(edm::ProductID const &) const override
Definition: BareRootProductGetter.cc:70
SiStripPI::max
Definition: SiStripPayloadInspectorHelper.h:169
BareRootProductGetter::createNewBuffer
Buffer * createNewBuffer(edm::BranchID const &) const
Definition: BareRootProductGetter.cc:278
edm::WrapperBase
Definition: WrapperBase.h:23
edm::BranchDescription::branchName
std::string const & branchName() const
Definition: BranchDescription.h:119
edm::wrappedClassName
std::string wrappedClassName(std::string const &iFullName)
Definition: WrappedClassName.cc:4
edm::ThinnedAssociation::hasParentIndex
bool hasParentIndex(unsigned int parentIndex, unsigned int &thinnedIndex) const
Definition: ThinnedAssociation.cc:9
edm::ThinnedAssociation::parentCollectionID
ProductID const & parentCollectionID() const
Definition: ThinnedAssociation.h:18
fwlite::BranchMapReader::getFile
TFile const * getFile() const
Definition: BranchMapReader.h:92
eostools.move
def move(src, dest)
Definition: eostools.py:511
edm::ThinnedAssociationsHelper::parentBegin
std::vector< ThinnedAssociationBranches >::const_iterator parentBegin(BranchID const &) const
Definition: ThinnedAssociationsHelper.cc:25
Exception
Definition: hltDiff.cc:246
edm::BranchDescription
Definition: BranchDescription.h:32
edm::BranchDescription::className
std::string const & className() const
Definition: BranchDescription.h:79
crabWrapper.key
key
Definition: crabWrapper.py:19
class-composition.parent
parent
Definition: class-composition.py:88
edm::ProductID
Definition: ProductID.h:27