CMS 3D CMS Logo

List of all members | Classes | Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Types | Private Member Functions | Private Attributes
edm::PoolOutputModule Class Reference

#include <PoolOutputModule.h>

Inheritance diagram for edm::PoolOutputModule:
edm::one::OutputModule< WatchInputFiles > edm::one::OutputModuleBase edm::EDConsumerBase edm::TimeoutPoolOutputModule dqmservices::JsonWritingTimeoutPoolOutputModule

Classes

struct  AuxItem
 
struct  OutputItem
 
struct  SpecialSplitLevelForBranch
 

Public Types

typedef std::array< AuxItem, NumBranchTypesAuxItemArray
 
enum  DropMetaData { DropNone, DropDroppedPrior, DropPrior, DropAll }
 
typedef std::vector< OutputItemOutputItemList
 
typedef std::array< OutputItemList, NumBranchTypesOutputItemListArray
 
- Public Types inherited from edm::one::OutputModuleBase
typedef OutputModuleBase ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 

Public Member Functions

AuxItemArray const & auxItems () const
 
std::string const & basketOrder () const
 
int const & basketSize () const
 
BranchChildren const & branchChildren () const
 
std::string const & catalog () const
 
std::string const & compressionAlgorithm () const
 
int const & compressionLevel () const
 
std::string const & currentFileName () const
 
DropMetaData const & dropMetaData () const
 
int eventAutoFlushSize () const
 
std::string const & fileName () const
 
int const & inputFileCount () const
 
std::string const & logicalFileName () const
 
unsigned int const & maxFileSize () const
 
std::string const & moduleLabel () const
 
PoolOutputModuleoperator= (PoolOutputModule const &)=delete
 
bool const & overrideInputFileSplitLevels () const
 
 PoolOutputModule (ParameterSet const &ps)
 
 PoolOutputModule (PoolOutputModule const &)=delete
 
OutputItemListArrayselectedOutputItemList ()
 
OutputItemListArray const & selectedOutputItemList () const
 
int const & splitLevel () const
 
int const & treeMaxVirtualSize () const
 
int const & whyNotFastClonable () const
 
 ~PoolOutputModule () override
 
- Public Member Functions inherited from edm::one::OutputModule< WatchInputFiles >
SerialTaskQueueglobalLuminosityBlocksQueue () final
 
SerialTaskQueueglobalRunsQueue () final
 
 OutputModule (edm::ParameterSet const &iPSet)
 
bool wantsGlobalLuminosityBlocks () const final
 
bool wantsGlobalRuns () const final
 
- Public Member Functions inherited from edm::one::OutputModuleBase
BranchIDLists const * branchIDLists ()
 
std::array< bool, NumBranchTypes > const & hasNewlyDroppedBranch () const
 
SelectedProductsForBranchType const & keptProducts () const
 
int maxEvents () const
 
const ModuleDescriptionmoduleDescription () const
 
OutputModuleBaseoperator= (OutputModuleBase const &)=delete
 
 OutputModuleBase (OutputModuleBase const &)=delete
 
 OutputModuleBase (ParameterSet const &pset)
 
std::string const & processName () const
 
int remainingEvents () const
 
bool selected (BranchDescription const &desc) const
 
void selectProducts (ProductRegistry const &preg, ThinnedAssociationsHelper const &)
 
SharedResourcesAcquirersharedResourcesAcquirer ()
 
SubProcessParentageHelper const * subProcessParentageHelper () const
 
ThinnedAssociationsHelper const * thinnedAssociationsHelper () const
 
bool wantAllEvents () const
 
bool wantsStreamLuminosityBlocks () const
 
bool wantsStreamRuns () const
 
 ~OutputModuleBase () override
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase &&)=default
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
ESProxyIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Static Public Member Functions

static void fillDescription (ParameterSetDescription &desc)
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
- Static Public Member Functions inherited from edm::one::OutputModuleBase
static const std::string & baseType ()
 
static void fillDescription (ParameterSetDescription &desc, std::vector< std::string > const &iDefaultOutputCommands=ProductSelectorRules::defaultSelectionStrings())
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 

Protected Member Functions

virtual void doExtrasAfterCloseFile ()
 
virtual std::pair< std::string, std::string > physicalAndLogicalNameForNewFile ()
 
bool shouldWeCloseFile () const override
 allow inheriting classes to override but still be able to call this method in the overridden version More...
 
void write (EventForOutput const &e) override
 
- Protected Member Functions inherited from edm::one::OutputModuleBase
void configure (OutputModuleDescription const &desc)
 
ModuleDescription const & description () const
 
void doBeginJob ()
 
bool doBeginLuminosityBlock (LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
 
bool doBeginRun (RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
 
void doEndJob ()
 
bool doEndLuminosityBlock (LuminosityBlockPrincipal const &lbp, EventSetupImpl const &c, ModuleCallingContext const *)
 
bool doEndRun (RunPrincipal const &rp, EventSetupImpl const &c, ModuleCallingContext const *)
 
bool doEvent (EventPrincipal const &ep, EventSetupImpl const &c, ActivityRegistry *, ModuleCallingContext const *)
 
void doPreallocate (PreallocationConfiguration const &)
 
std::map< BranchID::value_type, BranchID::value_type > const & droppedBranchIDToKeptBranchID ()
 
virtual void preallocLumis (unsigned int)
 
ParameterSetID selectorConfig () const
 
void setEventSelectionInfo (std::map< std::string, std::vector< std::pair< std::string, int >>> const &outputModulePathPositions, bool anyProductProduced)
 
- Protected Member Functions inherited from edm::EDConsumerBase
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes ()
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes (ESInputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 

Private Types

typedef std::map< BranchID, std::set< ParentageID > > BranchParents
 

Private Member Functions

void beginInputFile (FileBlock const &fb)
 
void beginJob () override
 
void fillDependencyGraph ()
 
void fillSelectedItemList (BranchType branchtype, TTree *theInputTree)
 
void finishEndFile ()
 
bool isFileOpen () const override
 
void openFile (FileBlock const &fb) override
 
void preActionBeforeRunEventAsync (WaitingTask *iTask, ModuleCallingContext const &iModuleCallingContext, Principal const &iPrincipal) const override
 
void reallyCloseFile () override
 
void reallyOpenFile ()
 
void respondToCloseInputFile (FileBlock const &fb) override
 
void respondToOpenInputFile (FileBlock const &fb) override
 
void setProcessesWithSelectedMergeableRunProducts (std::set< std::string > const &) override
 
void startEndFile ()
 
void updateBranchParents (EventForOutput const &e)
 
void updateBranchParentsForOneBranch (ProductProvenanceRetriever const *provRetriever, BranchID const &branchID)
 
void writeBranchIDListRegistry ()
 
void writeFileFormatVersion ()
 
void writeFileIdentifier ()
 
void writeIndexIntoFile ()
 
void writeLuminosityBlock (LuminosityBlockForOutput const &lb) override
 
void writeParameterSetRegistry ()
 
void writeParentageRegistry ()
 
void writeProcessHistoryRegistry ()
 
void writeProductDependencies ()
 
void writeProductDescriptionRegistry ()
 
void writeRun (RunForOutput const &r) override
 
void writeStoredMergeableRunProductMetadata ()
 
void writeThinnedAssociationsHelper ()
 

Private Attributes

AuxItemArray auxItems_
 
std::string basketOrder_
 
const int basketSize_
 
BranchChildren branchChildren_
 
BranchParents branchParents_
 
const std::string catalog_
 
unsigned int childIndex_
 
const std::string compressionAlgorithm_
 
const int compressionLevel_
 
DropMetaData dropMetaData_
 
const int eventAutoFlushSize_
 
const std::string fileName_
 
bool initializedFromInput_
 
int inputFileCount_
 
const std::string logicalFileName_
 
unsigned const int maxFileSize_
 
const std::string moduleLabel_
 
unsigned int numberOfDigitsInIndex_
 
int outputFileCount_
 
bool overrideInputFileSplitLevels_
 
std::vector< std::string > processesWithSelectedMergeableRunProducts_
 
std::vector< BranchIDproducedBranches_
 
edm::propagate_const< std::unique_ptr< RootOutputFile > > rootOutputFile_
 
RootServiceChecker rootServiceChecker_
 
OutputItemListArray selectedOutputItemList_
 
std::vector< SpecialSplitLevelForBranchspecialSplitLevelForBranches_
 
const int splitLevel_
 
std::string statusFileName_
 
const int treeMaxVirtualSize_
 
int whyNotFastClonable_
 

Detailed Description

Definition at line 39 of file PoolOutputModule.h.

Member Typedef Documentation

◆ AuxItemArray

Definition at line 75 of file PoolOutputModule.h.

◆ BranchParents

typedef std::map<BranchID, std::set<ParentageID> > edm::PoolOutputModule::BranchParents
private

Definition at line 162 of file PoolOutputModule.h.

◆ OutputItemList

Definition at line 115 of file PoolOutputModule.h.

◆ OutputItemListArray

Definition at line 117 of file PoolOutputModule.h.

Member Enumeration Documentation

◆ DropMetaData

Enumerator
DropNone 
DropDroppedPrior 
DropPrior 
DropAll 

Definition at line 41 of file PoolOutputModule.h.

Constructor & Destructor Documentation

◆ PoolOutputModule() [1/2]

edm::PoolOutputModule::PoolOutputModule ( ParameterSet const &  ps)
explicit

Definition at line 36 of file PoolOutputModule.cc.

38  one::OutputModule<WatchInputFiles>(pset),
40  auxItems_(),
42  fileName_(pset.getUntrackedParameter<std::string>("fileName")),
43  logicalFileName_(pset.getUntrackedParameter<std::string>("logicalFileName")),
44  catalog_(pset.getUntrackedParameter<std::string>("catalog")),
45  maxFileSize_(pset.getUntrackedParameter<int>("maxSize")),
46  compressionLevel_(pset.getUntrackedParameter<int>("compressionLevel")),
47  compressionAlgorithm_(pset.getUntrackedParameter<std::string>("compressionAlgorithm")),
48  basketSize_(pset.getUntrackedParameter<int>("basketSize")),
49  eventAutoFlushSize_(pset.getUntrackedParameter<int>("eventAutoFlushCompressedSize")),
50  splitLevel_(std::min<int>(pset.getUntrackedParameter<int>("splitLevel") + 1, 99)),
51  basketOrder_(pset.getUntrackedParameter<std::string>("sortBaskets")),
52  treeMaxVirtualSize_(pset.getUntrackedParameter<int>("treeMaxVirtualSize")),
53  whyNotFastClonable_(pset.getUntrackedParameter<bool>("fastCloning") ? FileBlock::CanFastClone
56  moduleLabel_(pset.getParameter<std::string>("@module_label")),
57  initializedFromInput_(false),
59  inputFileCount_(0),
60  childIndex_(0U),
64  overrideInputFileSplitLevels_(pset.getUntrackedParameter<bool>("overrideInputFileSplitLevels")),
66  statusFileName_() {
67  if (pset.getUntrackedParameter<bool>("writeStatusFile")) {
68  std::ostringstream statusfilename;
69  statusfilename << moduleLabel_ << '_' << getpid();
70  statusFileName_ = statusfilename.str();
71  }
72 
73  std::string dropMetaData(pset.getUntrackedParameter<std::string>("dropMetaData"));
74  if (dropMetaData.empty())
76  else if (dropMetaData == std::string("NONE"))
78  else if (dropMetaData == std::string("DROPPED"))
80  else if (dropMetaData == std::string("PRIOR"))
82  else if (dropMetaData == std::string("ALL"))
84  else {
85  throw edm::Exception(errors::Configuration, "Illegal dropMetaData parameter value: ")
86  << dropMetaData << ".\n"
87  << "Legal values are 'NONE', 'DROPPED', 'PRIOR', and 'ALL'.\n";
88  }
89 
90  if (!wantAllEvents()) {
92  }
93 
94  auto const& specialSplit{pset.getUntrackedParameterSetVector("overrideBranchesSplitLevel")};
95 
96  specialSplitLevelForBranches_.reserve(specialSplit.size());
97  for (auto const& s : specialSplit) {
98  specialSplitLevelForBranches_.emplace_back(s.getUntrackedParameter<std::string>("branch"),
99  s.getUntrackedParameter<int>("splitLevel"));
100  }
101 
102  // We don't use this next parameter, but we read it anyway because it is part
103  // of the configuration of this module. An external parser creates the
104  // configuration by reading this source code.
105  pset.getUntrackedParameterSet("dataset");
106  }

References edm::errors::Configuration, DropAll, DropDroppedPrior, dropMetaData(), dropMetaData_, DropNone, DropPrior, edm::FileBlock::EventSelectionUsed, Exception, moduleLabel_, muonDTDigis_cfi::pset, alignCSCRings::s, specialSplitLevelForBranches_, statusFileName_, AlCaHLTBitMon_QueryRunRegistry::string, edm::one::OutputModuleBase::wantAllEvents(), and whyNotFastClonable_.

◆ ~PoolOutputModule()

edm::PoolOutputModule::~PoolOutputModule ( )
override

Definition at line 269 of file PoolOutputModule.cc.

269 {}

◆ PoolOutputModule() [2/2]

edm::PoolOutputModule::PoolOutputModule ( PoolOutputModule const &  )
delete

Member Function Documentation

◆ auxItems()

AuxItemArray const& edm::PoolOutputModule::auxItems ( ) const
inline

Definition at line 76 of file PoolOutputModule.h.

76 { return auxItems_; }

References auxItems_.

◆ basketOrder()

std::string const& edm::PoolOutputModule::basketOrder ( ) const
inline

Definition at line 53 of file PoolOutputModule.h.

53 { return basketOrder_; }

References basketOrder_.

◆ basketSize()

int const& edm::PoolOutputModule::basketSize ( ) const
inline

Definition at line 50 of file PoolOutputModule.h.

50 { return basketSize_; }

References basketSize_.

◆ beginInputFile()

void edm::PoolOutputModule::beginInputFile ( FileBlock const &  fb)
private

Definition at line 225 of file PoolOutputModule.cc.

225  {
226  if (isFileOpen()) {
227  //Faster to read ChildrenBranches directly from input
228  // file than to build it every event
229  auto const& branchToChildMap = fb.branchChildren().childLookup();
230  for (auto const& parentToChildren : branchToChildMap) {
231  for (auto const& child : parentToChildren.second) {
232  branchChildren_.insertChild(parentToChildren.first, child);
233  }
234  }
235  rootOutputFile_->beginInputFile(fb, remainingEvents());
236  }
237  }

References branchChildren_, benchmark_cfg::fb, edm::BranchChildren::insertChild(), isFileOpen(), edm::one::OutputModuleBase::remainingEvents(), and rootOutputFile_.

Referenced by openFile(), and respondToOpenInputFile().

◆ beginJob()

void edm::PoolOutputModule::beginJob ( void  )
overrideprivatevirtual

Reimplemented from edm::one::OutputModuleBase.

Definition at line 108 of file PoolOutputModule.cc.

108  {
110  for (auto const& prod : reg->productList()) {
111  BranchDescription const& desc = prod.second;
112  if (desc.produced() && desc.branchType() == InEvent && !desc.isAlias()) {
113  producedBranches_.emplace_back(desc.branchID());
114  }
115  }
116  }

References edm::BranchDescription::branchID(), edm::BranchDescription::branchType(), edm::InEvent, edm::BranchDescription::isAlias(), dumpMFGeometry_cfg::prod, edm::BranchDescription::produced(), and producedBranches_.

◆ branchChildren()

BranchChildren const& edm::PoolOutputModule::branchChildren ( ) const
inline

Definition at line 135 of file PoolOutputModule.h.

135 { return branchChildren_; }

References branchChildren_.

◆ catalog()

std::string const& edm::PoolOutputModule::catalog ( ) const
inline

Definition at line 57 of file PoolOutputModule.h.

57 { return catalog_; }

References catalog_.

◆ compressionAlgorithm()

std::string const& edm::PoolOutputModule::compressionAlgorithm ( ) const
inline

Definition at line 49 of file PoolOutputModule.h.

49 { return compressionAlgorithm_; }

References compressionAlgorithm_.

◆ compressionLevel()

int const& edm::PoolOutputModule::compressionLevel ( ) const
inline

Definition at line 48 of file PoolOutputModule.h.

48 { return compressionLevel_; }

References compressionLevel_.

◆ currentFileName()

std::string const & edm::PoolOutputModule::currentFileName ( ) const

Definition at line 118 of file PoolOutputModule.cc.

118 { return rootOutputFile_->fileName(); }

References rootOutputFile_.

Referenced by edm::TimeoutPoolOutputModule::shouldWeCloseFile().

◆ doExtrasAfterCloseFile()

void edm::PoolOutputModule::doExtrasAfterCloseFile ( )
protectedvirtual

Reimplemented in dqmservices::JsonWritingTimeoutPoolOutputModule.

Definition at line 328 of file PoolOutputModule.cc.

328 {}

Referenced by reallyCloseFile().

◆ dropMetaData()

DropMetaData const& edm::PoolOutputModule::dropMetaData ( ) const
inline

Definition at line 56 of file PoolOutputModule.h.

56 { return dropMetaData_; }

References dropMetaData_.

Referenced by PoolOutputModule().

◆ eventAutoFlushSize()

int edm::PoolOutputModule::eventAutoFlushSize ( ) const
inline

Definition at line 51 of file PoolOutputModule.h.

51 { return eventAutoFlushSize_; }

References eventAutoFlushSize_.

Referenced by edm::RootOutputFile::RootOutputFile().

◆ fileName()

std::string const& edm::PoolOutputModule::fileName ( ) const
inline

Definition at line 46 of file PoolOutputModule.h.

46 { return fileName_; }

References fileName_.

Referenced by physicalAndLogicalNameForNewFile().

◆ fillDependencyGraph()

void edm::PoolOutputModule::fillDependencyGraph ( )
private

Definition at line 413 of file PoolOutputModule.cc.

413  {
414  for (auto const& branchParent : branchParents_) {
415  BranchID const& child = branchParent.first;
416  std::set<ParentageID> const& eIds = branchParent.second;
417  for (auto const& eId : eIds) {
418  Parentage entryDesc;
419  ParentageRegistry::instance()->getMapped(eId, entryDesc);
420  std::vector<BranchID> const& parents = entryDesc.parents();
421  for (auto const& parent : parents) {
423  }
424  }
425  }
426  }

References branchChildren_, branchParents_, edm::ParentageRegistry::getMapped(), edm::BranchChildren::insertChild(), edm::ParentageRegistry::instance(), class-composition::parent, parents, and edm::Parentage::parents().

Referenced by reallyCloseFile().

◆ fillDescription()

void edm::PoolOutputModule::fillDescription ( ParameterSetDescription desc)
static

Definition at line 428 of file PoolOutputModule.cc.

428  {
429  std::string defaultString;
430 
431  desc.setComment("Writes runs, lumis, and events into EDM/ROOT files.");
432  desc.addUntracked<std::string>("fileName")->setComment("Name of output file.");
433  desc.addUntracked<std::string>("logicalFileName", defaultString)
434  ->setComment("Passed to job report. Otherwise unused by module.");
435  desc.addUntracked<std::string>("catalog", defaultString)
436  ->setComment("Passed to job report. Otherwise unused by module.");
437  desc.addUntracked<int>("maxSize", 0x7f000000)
438  ->setComment(
439  "Maximum output file size, in kB.\n"
440  "If over maximum, new output file will be started at next input file transition.");
441  desc.addUntracked<int>("compressionLevel", 9)->setComment("ROOT compression level of output file.");
442  desc.addUntracked<std::string>("compressionAlgorithm", "ZLIB")
443  ->setComment("Algorithm used to compress data in the ROOT output file, allowed values are ZLIB and LZMA");
444  desc.addUntracked<int>("basketSize", 16384)->setComment("Default ROOT basket size in output file.");
445  desc.addUntracked<int>("eventAutoFlushCompressedSize", 20 * 1024 * 1024)
446  ->setComment(
447  "Set ROOT auto flush stored data size (in bytes) for event TTree. The value sets how large the compressed "
448  "buffer is allowed to get. The uncompressed buffer can be quite a bit larger than this depending on the "
449  "average compression ratio. The value of -1 just uses ROOT's default value. The value of 0 turns off this "
450  "feature.");
451  desc.addUntracked<int>("splitLevel", 99)->setComment("Default ROOT branch split level in output file.");
452  desc.addUntracked<std::string>("sortBaskets", std::string("sortbasketsbyoffset"))
453  ->setComment(
454  "Legal values: 'sortbasketsbyoffset', 'sortbasketsbybranch', 'sortbasketsbyentry'.\n"
455  "Used by ROOT when fast copying. Affects performance.");
456  desc.addUntracked<int>("treeMaxVirtualSize", -1)
457  ->setComment("Size of ROOT TTree TBasket cache. Affects performance.");
458  desc.addUntracked<bool>("fastCloning", true)
459  ->setComment(
460  "True: Allow fast copying, if possible.\n"
461  "False: Disable fast copying.");
462  desc.addUntracked<bool>("overrideInputFileSplitLevels", false)
463  ->setComment(
464  "False: Use branch split levels and basket sizes from input file, if possible.\n"
465  "True: Always use specified or default split levels and basket sizes.");
466  desc.addUntracked<bool>("writeStatusFile", false)
467  ->setComment("Write a status file. Intended for use by workflow management.");
468  desc.addUntracked<std::string>("dropMetaData", defaultString)
469  ->setComment(
470  "Determines handling of per product per event metadata. Options are:\n"
471  "'NONE': Keep all of it.\n"
472  "'DROPPED': Keep it for products produced in current process and all kept products. Drop it for dropped "
473  "products produced in prior processes.\n"
474  "'PRIOR': Keep it for products produced in current process. Drop it for products produced in prior "
475  "processes.\n"
476  "'ALL': Drop all of it.");
477  {
479  dataSet.setAllowAnything();
480  desc.addUntracked<ParameterSetDescription>("dataset", dataSet)
481  ->setComment("PSet is only used by Data Operations and not by this module.");
482  }
483  {
484  ParameterSetDescription specialSplit;
485  specialSplit.addUntracked<std::string>("branch")->setComment(
486  "Name of branch needing a special split level. The name can contain wildcards '*' and '?'");
487  specialSplit.addUntracked<int>("splitLevel")->setComment("The special split level for the branch");
488  desc.addVPSetUntracked("overrideBranchesSplitLevel", specialSplit, std::vector<ParameterSet>());
489  }
490  OutputModule::fillDescription(desc);
491  }

References edm::ParameterSetDescription::addUntracked(), edm::ParameterSetDescription::addVPSetUntracked(), EgammaPostProcessor_cfi::dataSet, edm::ParameterSetDescription::setComment(), and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by edm::TimeoutPoolOutputModule::fillDescriptions(), and fillDescriptions().

◆ fillDescriptions()

void edm::PoolOutputModule::fillDescriptions ( ConfigurationDescriptions descriptions)
static

Definition at line 493 of file PoolOutputModule.cc.

493  {
496  descriptions.add("edmOutput", desc);
497  }

References edm::ConfigurationDescriptions::add(), and fillDescription().

◆ fillSelectedItemList()

void edm::PoolOutputModule::fillSelectedItemList ( BranchType  branchtype,
TTree *  theInputTree 
)
private

Definition at line 178 of file PoolOutputModule.cc.

178  {
179  SelectedProducts const& keptVector = keptProducts()[branchType];
180  OutputItemList& outputItemList = selectedOutputItemList_[branchType];
181  AuxItem& auxItem = auxItems_[branchType];
182 
183  // Fill AuxItem
184  if (theInputTree != nullptr && !overrideInputFileSplitLevels_) {
185  TBranch* auxBranch = theInputTree->GetBranch(BranchTypeToAuxiliaryBranchName(branchType).c_str());
186  if (auxBranch) {
187  auxItem.basketSize_ = auxBranch->GetBasketSize();
188  } else {
189  auxItem.basketSize_ = basketSize_;
190  }
191  } else {
192  auxItem.basketSize_ = basketSize_;
193  }
194 
195  // Fill outputItemList with an entry for each branch.
196  for (auto const& kept : keptVector) {
199 
200  BranchDescription const& prod = *kept.first;
201  TBranch* theBranch = ((!prod.produced() && theInputTree != nullptr && !overrideInputFileSplitLevels_)
202  ? theInputTree->GetBranch(prod.branchName().c_str())
203  : nullptr);
204 
205  if (theBranch != nullptr) {
206  splitLevel = theBranch->GetSplitLevel();
207  basketSize = theBranch->GetBasketSize();
208  } else {
209  splitLevel = (prod.splitLevel() == BranchDescription::invalidSplitLevel ? splitLevel_ : prod.splitLevel());
210  for (auto const& b : specialSplitLevelForBranches_) {
211  if (b.match(prod.branchName())) {
212  splitLevel = b.splitLevel_;
213  }
214  }
215  basketSize = (prod.basketSize() == BranchDescription::invalidBasketSize ? basketSize_ : prod.basketSize());
216  }
217  outputItemList.emplace_back(&prod, kept.second, splitLevel, basketSize);
218  }
219 
220  // Sort outputItemList to allow fast copying.
221  // The branches in outputItemList must be in the same order as in the input tree, with all new branches at the end.
222  sort_all(outputItemList, OutputItem::Sorter(theInputTree));
223  }

References auxItems_, b, edm::PoolOutputModule::OutputItem::basketSize(), edm::PoolOutputModule::AuxItem::basketSize_, edm::PoolOutputModule::OutputItem::basketSize_, edm::BranchTypeToAuxiliaryBranchName(), edm::BranchDescription::invalidBasketSize, edm::BranchDescription::invalidSplitLevel, edm::one::OutputModuleBase::keptProducts(), overrideInputFileSplitLevels_, dumpMFGeometry_cfg::prod, selectedOutputItemList_, edm::sort_all(), specialSplitLevelForBranches_, edm::PoolOutputModule::OutputItem::splitLevel(), and edm::PoolOutputModule::OutputItem::splitLevel_.

Referenced by respondToOpenInputFile().

◆ finishEndFile()

void edm::PoolOutputModule::finishEndFile ( )
private

Definition at line 324 of file PoolOutputModule.cc.

324  {
325  rootOutputFile_->finishEndFile();
326  rootOutputFile_ = nullptr;
327  } // propagate_const<T> has no reset() function

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ inputFileCount()

int const& edm::PoolOutputModule::inputFileCount ( ) const
inline

Definition at line 60 of file PoolOutputModule.h.

60 { return inputFileCount_; }

References inputFileCount_.

◆ isFileOpen()

bool edm::PoolOutputModule::isFileOpen ( ) const
overrideprivatevirtual

Reimplemented from edm::one::OutputModuleBase.

Definition at line 329 of file PoolOutputModule.cc.

329 { return rootOutputFile_.get() != nullptr; }

References rootOutputFile_.

Referenced by beginInputFile(), and openFile().

◆ logicalFileName()

std::string const& edm::PoolOutputModule::logicalFileName ( ) const
inline

Definition at line 47 of file PoolOutputModule.h.

47 { return logicalFileName_; }

References logicalFileName_.

Referenced by physicalAndLogicalNameForNewFile().

◆ maxFileSize()

unsigned int const& edm::PoolOutputModule::maxFileSize ( ) const
inline

Definition at line 59 of file PoolOutputModule.h.

59 { return maxFileSize_; }

References maxFileSize_.

◆ moduleLabel()

std::string const& edm::PoolOutputModule::moduleLabel ( ) const
inline

Definition at line 58 of file PoolOutputModule.h.

58 { return moduleLabel_; }

References moduleLabel_.

◆ openFile()

void edm::PoolOutputModule::openFile ( FileBlock const &  fb)
overrideprivatevirtual

Reimplemented from edm::one::OutputModuleBase.

Definition at line 239 of file PoolOutputModule.cc.

239  {
240  if (!isFileOpen()) {
241  reallyOpenFile();
243  }
244  }

References beginInputFile(), benchmark_cfg::fb, isFileOpen(), and reallyOpenFile().

◆ operator=()

PoolOutputModule& edm::PoolOutputModule::operator= ( PoolOutputModule const &  )
delete

◆ overrideInputFileSplitLevels()

bool const& edm::PoolOutputModule::overrideInputFileSplitLevels ( ) const
inline

Definition at line 55 of file PoolOutputModule.h.

References overrideInputFileSplitLevels_.

◆ physicalAndLogicalNameForNewFile()

std::pair< std::string, std::string > edm::PoolOutputModule::physicalAndLogicalNameForNewFile ( )
protectedvirtual

Reimplemented in dqmservices::JsonWritingTimeoutPoolOutputModule.

Definition at line 332 of file PoolOutputModule.cc.

332  {
333  if (inputFileCount_ == 0) {
334  throw edm::Exception(errors::LogicError) << "Attempt to open output file before input file. "
335  << "Please report this to the core framework developers.\n";
336  }
337  std::string suffix(".root");
339  bool ext = (offset == fileName().size() - suffix.size());
340  if (!ext)
341  suffix.clear();
342  std::string fileBase(ext ? fileName().substr(0, offset) : fileName());
343  std::ostringstream ofilename;
344  std::ostringstream lfilename;
345  ofilename << fileBase;
346  lfilename << logicalFileName();
348  ofilename << '_' << std::setw(numberOfDigitsInIndex_) << std::setfill('0') << childIndex_;
349  if (!logicalFileName().empty()) {
350  lfilename << '_' << std::setw(numberOfDigitsInIndex_) << std::setfill('0') << childIndex_;
351  }
352  }
353  if (outputFileCount_) {
354  ofilename << std::setw(3) << std::setfill('0') << outputFileCount_;
355  if (!logicalFileName().empty()) {
356  lfilename << std::setw(3) << std::setfill('0') << outputFileCount_;
357  }
358  }
359  ofilename << suffix;
361 
362  return std::make_pair(ofilename.str(), lfilename.str());
363  }

References childIndex_, relativeConstraints::empty, Exception, fileName(), inputFileCount_, logicalFileName(), edm::errors::LogicError, numberOfDigitsInIndex_, hltrates_dqm_sourceclient-live_cfg::offset, outputFileCount_, AlCaHLTBitMon_QueryRunRegistry::string, and createPayload::suffix.

Referenced by reallyOpenFile().

◆ preActionBeforeRunEventAsync()

void edm::PoolOutputModule::preActionBeforeRunEventAsync ( WaitingTask iTask,
ModuleCallingContext const &  iModuleCallingContext,
Principal const &  iPrincipal 
) const
overrideprivatevirtual

Reimplemented from edm::one::OutputModuleBase.

Definition at line 399 of file PoolOutputModule.cc.

401  {
402  if (DropAll != dropMetaData_) {
403  auto const* ep = dynamic_cast<EventPrincipal const*>(&iPrincipal);
404  if (ep) {
405  auto pr = ep->productProvenanceRetrieverPtr();
406  if (pr) {
407  pr->readProvenanceAsync(iTask, &iModuleCallingContext);
408  }
409  }
410  }
411  }

References DropAll, dropMetaData_, and SiStripBadComponentsDQMServiceTemplate_cfg::ep.

◆ reallyCloseFile()

void edm::PoolOutputModule::reallyCloseFile ( )
overrideprivatevirtual

◆ reallyOpenFile()

void edm::PoolOutputModule::reallyOpenFile ( )
private

Definition at line 365 of file PoolOutputModule.cc.

365  {
367  rootOutputFile_ = std::make_unique<RootOutputFile>(
368  this,
369  names.first,
370  names.second,
371  processesWithSelectedMergeableRunProducts_); // propagate_const<T> has no reset() function
372  }

References names, physicalAndLogicalNameForNewFile(), processesWithSelectedMergeableRunProducts_, and rootOutputFile_.

Referenced by openFile().

◆ respondToCloseInputFile()

void edm::PoolOutputModule::respondToCloseInputFile ( FileBlock const &  fb)
overrideprivate

Definition at line 260 of file PoolOutputModule.cc.

260  {
261  if (rootOutputFile_)
262  rootOutputFile_->respondToCloseInputFile(fb);
263  }

References benchmark_cfg::fb, and rootOutputFile_.

◆ respondToOpenInputFile()

void edm::PoolOutputModule::respondToOpenInputFile ( FileBlock const &  fb)
overrideprivate

Definition at line 246 of file PoolOutputModule.cc.

246  {
247  if (!initializedFromInput_) {
248  for (int i = InEvent; i < NumBranchTypes; ++i) {
249  BranchType branchType = static_cast<BranchType>(i);
250  TTree* theInputTree =
251  (branchType == InEvent ? fb.tree() : (branchType == InLumi ? fb.lumiTree() : fb.runTree()));
252  fillSelectedItemList(branchType, theInputTree);
253  }
254  initializedFromInput_ = true;
255  }
256  ++inputFileCount_;
258  }

References beginInputFile(), benchmark_cfg::fb, fillSelectedItemList(), mps_fire::i, edm::InEvent, initializedFromInput_, edm::InLumi, inputFileCount_, and edm::NumBranchTypes.

◆ selectedOutputItemList() [1/2]

OutputItemListArray& edm::PoolOutputModule::selectedOutputItemList ( )
inline

Definition at line 133 of file PoolOutputModule.h.

133 { return selectedOutputItemList_; }

References selectedOutputItemList_.

◆ selectedOutputItemList() [2/2]

OutputItemListArray const& edm::PoolOutputModule::selectedOutputItemList ( ) const
inline

Definition at line 131 of file PoolOutputModule.h.

131 { return selectedOutputItemList_; }

References selectedOutputItemList_.

Referenced by edm::RootOutputFile::RootOutputFile().

◆ setProcessesWithSelectedMergeableRunProducts()

void edm::PoolOutputModule::setProcessesWithSelectedMergeableRunProducts ( std::set< std::string > const &  processes)
overrideprivatevirtual

Reimplemented from edm::one::OutputModuleBase.

Definition at line 265 of file PoolOutputModule.cc.

265  {
267  }

References dqmiodatasetharvest::processes, and processesWithSelectedMergeableRunProducts_.

◆ shouldWeCloseFile()

bool edm::PoolOutputModule::shouldWeCloseFile ( ) const
overrideprotectedvirtual

allow inheriting classes to override but still be able to call this method in the overridden version

Reimplemented from edm::one::OutputModuleBase.

Reimplemented in edm::TimeoutPoolOutputModule.

Definition at line 330 of file PoolOutputModule.cc.

330 { return rootOutputFile_->shouldWeCloseFile(); }

References rootOutputFile_.

Referenced by edm::TimeoutPoolOutputModule::shouldWeCloseFile().

◆ splitLevel()

int const& edm::PoolOutputModule::splitLevel ( ) const
inline

Definition at line 52 of file PoolOutputModule.h.

52 { return splitLevel_; }

References splitLevel_.

◆ startEndFile()

void edm::PoolOutputModule::startEndFile ( )
private

Definition at line 309 of file PoolOutputModule.cc.

309 {}

Referenced by reallyCloseFile().

◆ treeMaxVirtualSize()

int const& edm::PoolOutputModule::treeMaxVirtualSize ( ) const
inline

Definition at line 54 of file PoolOutputModule.h.

54 { return treeMaxVirtualSize_; }

References treeMaxVirtualSize_.

◆ updateBranchParents()

void edm::PoolOutputModule::updateBranchParents ( EventForOutput const &  e)
private

Definition at line 386 of file PoolOutputModule.cc.

386  {
387  ProductProvenanceRetriever const* provRetriever = e.productProvenanceRetrieverPtr();
388  for (auto const& bid : producedBranches_) {
389  updateBranchParentsForOneBranch(provRetriever, bid);
390  }
391  SubProcessParentageHelper const* helper = subProcessParentageHelper();
392  if (helper) {
393  for (auto const& bid : subProcessParentageHelper()->producedProducts()) {
394  updateBranchParentsForOneBranch(provRetriever, bid);
395  }
396  }
397  }

References MillePedeFileConverter_cfg::e, producedBranches_, edm::one::OutputModuleBase::subProcessParentageHelper(), and updateBranchParentsForOneBranch().

Referenced by write().

◆ updateBranchParentsForOneBranch()

void edm::PoolOutputModule::updateBranchParentsForOneBranch ( ProductProvenanceRetriever const *  provRetriever,
BranchID const &  branchID 
)
private

Definition at line 374 of file PoolOutputModule.cc.

375  {
376  ProductProvenance const* provenance = provRetriever->branchIDToProvenanceForProducedOnly(branchID);
377  if (provenance != nullptr) {
378  BranchParents::iterator it = branchParents_.find(branchID);
379  if (it == branchParents_.end()) {
380  it = branchParents_.insert(std::make_pair(branchID, std::set<ParentageID>())).first;
381  }
382  it->second.insert(provenance->parentageID());
383  }
384  }

References edm::PoolOutputModule::OutputItem::branchID(), edm::ProductProvenanceRetriever::branchIDToProvenanceForProducedOnly(), branchParents_, and edm::ProductProvenance::parentageID().

Referenced by updateBranchParents().

◆ whyNotFastClonable()

int const& edm::PoolOutputModule::whyNotFastClonable ( ) const
inline

Definition at line 61 of file PoolOutputModule.h.

61 { return whyNotFastClonable_; }

References whyNotFastClonable_.

◆ write()

void edm::PoolOutputModule::write ( EventForOutput const &  e)
overrideprotectedvirtual

Implements edm::one::OutputModuleBase.

Reimplemented in edm::TimeoutPoolOutputModule.

Definition at line 271 of file PoolOutputModule.cc.

271  {
273  rootOutputFile_->writeOne(e);
274  if (!statusFileName_.empty()) {
275  std::ofstream statusFile(statusFileName_.c_str());
276  statusFile << e.id() << " time: " << std::setprecision(3) << TimeOfDay() << '\n';
277  statusFile.close();
278  }
279  }

References MillePedeFileConverter_cfg::e, rootOutputFile_, statusFileName_, and updateBranchParents().

Referenced by edm::TimeoutPoolOutputModule::write().

◆ writeBranchIDListRegistry()

void edm::PoolOutputModule::writeBranchIDListRegistry ( )
private

Definition at line 321 of file PoolOutputModule.cc.

321 { rootOutputFile_->writeBranchIDListRegistry(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeFileFormatVersion()

void edm::PoolOutputModule::writeFileFormatVersion ( )
private

Definition at line 311 of file PoolOutputModule.cc.

311 { rootOutputFile_->writeFileFormatVersion(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeFileIdentifier()

void edm::PoolOutputModule::writeFileIdentifier ( )
private

Definition at line 312 of file PoolOutputModule.cc.

312 { rootOutputFile_->writeFileIdentifier(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeIndexIntoFile()

void edm::PoolOutputModule::writeIndexIntoFile ( )
private

Definition at line 313 of file PoolOutputModule.cc.

313 { rootOutputFile_->writeIndexIntoFile(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeLuminosityBlock()

void edm::PoolOutputModule::writeLuminosityBlock ( LuminosityBlockForOutput const &  lb)
overrideprivatevirtual

Implements edm::one::OutputModuleBase.

Definition at line 281 of file PoolOutputModule.cc.

281  {
282  rootOutputFile_->writeLuminosityBlock(lb);
283  }

References rootOutputFile_.

◆ writeParameterSetRegistry()

void edm::PoolOutputModule::writeParameterSetRegistry ( )
private

Definition at line 318 of file PoolOutputModule.cc.

318 { rootOutputFile_->writeParameterSetRegistry(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeParentageRegistry()

void edm::PoolOutputModule::writeParentageRegistry ( )
private

Definition at line 320 of file PoolOutputModule.cc.

320 { rootOutputFile_->writeParentageRegistry(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeProcessHistoryRegistry()

void edm::PoolOutputModule::writeProcessHistoryRegistry ( )
private

Definition at line 317 of file PoolOutputModule.cc.

317 { rootOutputFile_->writeProcessHistoryRegistry(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeProductDependencies()

void edm::PoolOutputModule::writeProductDependencies ( )
private

Definition at line 323 of file PoolOutputModule.cc.

323 { rootOutputFile_->writeProductDependencies(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeProductDescriptionRegistry()

void edm::PoolOutputModule::writeProductDescriptionRegistry ( )
private

Definition at line 319 of file PoolOutputModule.cc.

319 { rootOutputFile_->writeProductDescriptionRegistry(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeRun()

void edm::PoolOutputModule::writeRun ( RunForOutput const &  r)
overrideprivatevirtual

Implements edm::one::OutputModuleBase.

Definition at line 285 of file PoolOutputModule.cc.

285 { rootOutputFile_->writeRun(r); }

References alignCSCRings::r, and rootOutputFile_.

◆ writeStoredMergeableRunProductMetadata()

void edm::PoolOutputModule::writeStoredMergeableRunProductMetadata ( )
private

Definition at line 314 of file PoolOutputModule.cc.

314  {
315  rootOutputFile_->writeStoredMergeableRunProductMetadata();
316  }

References rootOutputFile_.

Referenced by reallyCloseFile().

◆ writeThinnedAssociationsHelper()

void edm::PoolOutputModule::writeThinnedAssociationsHelper ( )
private

Definition at line 322 of file PoolOutputModule.cc.

322 { rootOutputFile_->writeThinnedAssociationsHelper(); }

References rootOutputFile_.

Referenced by reallyCloseFile().

Member Data Documentation

◆ auxItems_

AuxItemArray edm::PoolOutputModule::auxItems_
private

Definition at line 185 of file PoolOutputModule.h.

Referenced by auxItems(), and fillSelectedItemList().

◆ basketOrder_

std::string edm::PoolOutputModule::basketOrder_
private

Definition at line 197 of file PoolOutputModule.h.

Referenced by basketOrder().

◆ basketSize_

const int edm::PoolOutputModule::basketSize_
private

Definition at line 194 of file PoolOutputModule.h.

Referenced by basketSize().

◆ branchChildren_

BranchChildren edm::PoolOutputModule::branchChildren_
private

◆ branchParents_

BranchParents edm::PoolOutputModule::branchParents_
private

◆ catalog_

const std::string edm::PoolOutputModule::catalog_
private

Definition at line 190 of file PoolOutputModule.h.

Referenced by catalog().

◆ childIndex_

unsigned int edm::PoolOutputModule::childIndex_
private

Definition at line 205 of file PoolOutputModule.h.

Referenced by physicalAndLogicalNameForNewFile().

◆ compressionAlgorithm_

const std::string edm::PoolOutputModule::compressionAlgorithm_
private

Definition at line 193 of file PoolOutputModule.h.

Referenced by compressionAlgorithm().

◆ compressionLevel_

const int edm::PoolOutputModule::compressionLevel_
private

Definition at line 192 of file PoolOutputModule.h.

Referenced by compressionLevel().

◆ dropMetaData_

DropMetaData edm::PoolOutputModule::dropMetaData_
private

◆ eventAutoFlushSize_

const int edm::PoolOutputModule::eventAutoFlushSize_
private

Definition at line 195 of file PoolOutputModule.h.

Referenced by eventAutoFlushSize().

◆ fileName_

const std::string edm::PoolOutputModule::fileName_
private

Definition at line 188 of file PoolOutputModule.h.

Referenced by fileName().

◆ initializedFromInput_

bool edm::PoolOutputModule::initializedFromInput_
private

Definition at line 202 of file PoolOutputModule.h.

Referenced by respondToOpenInputFile().

◆ inputFileCount_

int edm::PoolOutputModule::inputFileCount_
private

◆ logicalFileName_

const std::string edm::PoolOutputModule::logicalFileName_
private

Definition at line 189 of file PoolOutputModule.h.

Referenced by logicalFileName().

◆ maxFileSize_

unsigned const int edm::PoolOutputModule::maxFileSize_
private

Definition at line 191 of file PoolOutputModule.h.

Referenced by maxFileSize().

◆ moduleLabel_

const std::string edm::PoolOutputModule::moduleLabel_
private

◆ numberOfDigitsInIndex_

unsigned int edm::PoolOutputModule::numberOfDigitsInIndex_
private

Definition at line 206 of file PoolOutputModule.h.

Referenced by physicalAndLogicalNameForNewFile().

◆ outputFileCount_

int edm::PoolOutputModule::outputFileCount_
private

Definition at line 203 of file PoolOutputModule.h.

Referenced by physicalAndLogicalNameForNewFile().

◆ overrideInputFileSplitLevels_

bool edm::PoolOutputModule::overrideInputFileSplitLevels_
private

Definition at line 210 of file PoolOutputModule.h.

Referenced by fillSelectedItemList(), and overrideInputFileSplitLevels().

◆ processesWithSelectedMergeableRunProducts_

std::vector<std::string> edm::PoolOutputModule::processesWithSelectedMergeableRunProducts_
private

◆ producedBranches_

std::vector<BranchID> edm::PoolOutputModule::producedBranches_
private

Definition at line 209 of file PoolOutputModule.h.

Referenced by beginJob(), and updateBranchParents().

◆ rootOutputFile_

edm::propagate_const<std::unique_ptr<RootOutputFile> > edm::PoolOutputModule::rootOutputFile_
private

◆ rootServiceChecker_

RootServiceChecker edm::PoolOutputModule::rootServiceChecker_
private

Definition at line 184 of file PoolOutputModule.h.

◆ selectedOutputItemList_

OutputItemListArray edm::PoolOutputModule::selectedOutputItemList_
private

Definition at line 186 of file PoolOutputModule.h.

Referenced by fillSelectedItemList(), and selectedOutputItemList().

◆ specialSplitLevelForBranches_

std::vector<SpecialSplitLevelForBranch> edm::PoolOutputModule::specialSplitLevelForBranches_
private

Definition at line 187 of file PoolOutputModule.h.

Referenced by fillSelectedItemList(), and PoolOutputModule().

◆ splitLevel_

const int edm::PoolOutputModule::splitLevel_
private

Definition at line 196 of file PoolOutputModule.h.

Referenced by splitLevel().

◆ statusFileName_

std::string edm::PoolOutputModule::statusFileName_
private

Definition at line 212 of file PoolOutputModule.h.

Referenced by PoolOutputModule(), and write().

◆ treeMaxVirtualSize_

const int edm::PoolOutputModule::treeMaxVirtualSize_
private

Definition at line 198 of file PoolOutputModule.h.

Referenced by treeMaxVirtualSize().

◆ whyNotFastClonable_

int edm::PoolOutputModule::whyNotFastClonable_
private

Definition at line 199 of file PoolOutputModule.h.

Referenced by PoolOutputModule(), and whyNotFastClonable().

edm::one::OutputModuleBase::remainingEvents
int remainingEvents() const
Definition: OutputModuleBase.h:90
edm::PoolOutputModule::updateBranchParents
void updateBranchParents(EventForOutput const &e)
Definition: PoolOutputModule.cc:386
ext
Definition: memstream.h:15
edm::PoolOutputModule::branchChildren_
BranchChildren branchChildren_
Definition: PoolOutputModule.h:208
mps_fire.i
i
Definition: mps_fire.py:355
edm::one::OutputModuleBase::subProcessParentageHelper
SubProcessParentageHelper const * subProcessParentageHelper() const
Definition: OutputModuleBase.h:122
edm::PoolOutputModule::fileName_
const std::string fileName_
Definition: PoolOutputModule.h:188
edm::PoolOutputModule::maxFileSize_
unsigned const int maxFileSize_
Definition: PoolOutputModule.h:191
edm::PoolOutputModule::processesWithSelectedMergeableRunProducts_
std::vector< std::string > processesWithSelectedMergeableRunProducts_
Definition: PoolOutputModule.h:213
edm::sort_all
void sort_all(RandomAccessSequence &s)
wrappers for std::sort
Definition: Algorithms.h:92
edm::errors::LogicError
Definition: EDMException.h:37
edm::PoolOutputModule::OutputItemList
std::vector< OutputItem > OutputItemList
Definition: PoolOutputModule.h:115
edm::PoolOutputModule::rootOutputFile_
edm::propagate_const< std::unique_ptr< RootOutputFile > > rootOutputFile_
Definition: PoolOutputModule.h:211
edm::PoolOutputModule::writeParameterSetRegistry
void writeParameterSetRegistry()
Definition: PoolOutputModule.cc:318
edm::ParentageRegistry::instance
static ParentageRegistry * instance()
Definition: ParentageRegistry.cc:4
EgammaPostProcessor_cfi.dataSet
dataSet
Definition: EgammaPostProcessor_cfi.py:6
edm::PoolOutputModule::initializedFromInput_
bool initializedFromInput_
Definition: PoolOutputModule.h:202
edm::PoolOutputModule::whyNotFastClonable_
int whyNotFastClonable_
Definition: PoolOutputModule.h:199
edm::BranchChildren::clear
void clear()
Definition: BranchChildren.cc:36
edm::PoolOutputModule::fillSelectedItemList
void fillSelectedItemList(BranchType branchtype, TTree *theInputTree)
Definition: PoolOutputModule.cc:178
edm::PoolOutputModule::updateBranchParentsForOneBranch
void updateBranchParentsForOneBranch(ProductProvenanceRetriever const *provRetriever, BranchID const &branchID)
Definition: PoolOutputModule.cc:374
edm::PoolOutputModule::doExtrasAfterCloseFile
virtual void doExtrasAfterCloseFile()
Definition: PoolOutputModule.cc:328
edm::PoolOutputModule::inputFileCount_
int inputFileCount_
Definition: PoolOutputModule.h:204
edm::BranchType
BranchType
Definition: BranchType.h:11
edm::BranchTypeToAuxiliaryBranchName
std::string const & BranchTypeToAuxiliaryBranchName(BranchType const &branchType)
Definition: BranchType.cc:115
edm::one::OutputModuleBase::OutputModuleBase
OutputModuleBase(ParameterSet const &pset)
Definition: OutputModuleBase.cc:45
createPayload.suffix
suffix
Definition: createPayload.py:281
edm::NumBranchTypes
Definition: BranchType.h:11
edm::PoolOutputModule::specialSplitLevelForBranches_
std::vector< SpecialSplitLevelForBranch > specialSplitLevelForBranches_
Definition: PoolOutputModule.h:187
edm::SelectedProducts
std::vector< std::pair< BranchDescription const *, EDGetToken > > SelectedProducts
Definition: SelectedProducts.h:11
alignCSCRings.s
s
Definition: alignCSCRings.py:92
edm::FileBlock::CanFastClone
Definition: FileBlock.h:24
edm::PoolOutputModule::basketSize
int const & basketSize() const
Definition: PoolOutputModule.h:50
edm::PoolOutputModule::basketSize_
const int basketSize_
Definition: PoolOutputModule.h:194
trigger::size_type
uint16_t size_type
Definition: TriggerTypeDefs.h:18
edm::PoolOutputModule::moduleLabel_
const std::string moduleLabel_
Definition: PoolOutputModule.h:201
edm::PoolOutputModule::writeFileFormatVersion
void writeFileFormatVersion()
Definition: PoolOutputModule.cc:311
names
const std::string names[nVars_]
Definition: PhotonIDValueMapProducer.cc:122
edm::PoolOutputModule::selectedOutputItemList_
OutputItemListArray selectedOutputItemList_
Definition: PoolOutputModule.h:186
edm::PoolOutputModule::splitLevel_
const int splitLevel_
Definition: PoolOutputModule.h:196
edm::PoolOutputModule::producedBranches_
std::vector< BranchID > producedBranches_
Definition: PoolOutputModule.h:209
edm::PoolOutputModule::branchParents_
BranchParents branchParents_
Definition: PoolOutputModule.h:207
edm::BranchDescription::invalidSplitLevel
static const int invalidSplitLevel
Definition: BranchDescription.h:34
edm::PoolOutputModule::dropMetaData
DropMetaData const & dropMetaData() const
Definition: PoolOutputModule.h:56
dumpMFGeometry_cfg.prod
prod
Definition: dumpMFGeometry_cfg.py:24
edm::PoolOutputModule::eventAutoFlushSize_
const int eventAutoFlushSize_
Definition: PoolOutputModule.h:195
Service
edm::one::OutputModuleBase::wantAllEvents
bool wantAllEvents() const
Definition: OutputModuleBase.h:116
edm::InEvent
Definition: BranchType.h:11
edm::PoolOutputModule::overrideInputFileSplitLevels_
bool overrideInputFileSplitLevels_
Definition: PoolOutputModule.h:210
edm::PoolOutputModule::writeThinnedAssociationsHelper
void writeThinnedAssociationsHelper()
Definition: PoolOutputModule.cc:322
b
double b
Definition: hdecay.h:118
mitigatedMETSequence_cff.U
U
Definition: mitigatedMETSequence_cff.py:36
edm::PoolOutputModule::auxItems_
AuxItemArray auxItems_
Definition: PoolOutputModule.h:185
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
edm::PoolOutputModule::compressionAlgorithm_
const std::string compressionAlgorithm_
Definition: PoolOutputModule.h:193
edm::PoolOutputModule::reallyOpenFile
void reallyOpenFile()
Definition: PoolOutputModule.cc:365
edm::PoolOutputModule::writeIndexIntoFile
void writeIndexIntoFile()
Definition: PoolOutputModule.cc:313
edm::PoolOutputModule::numberOfDigitsInIndex_
unsigned int numberOfDigitsInIndex_
Definition: PoolOutputModule.h:206
sipixeldigitoraw
Definition: SiPixelDigiToRaw.cc:38
edm::InLumi
Definition: BranchType.h:11
edm::ParentageRegistry::getMapped
bool getMapped(key_type const &k, value_type &result) const
Definition: ParentageRegistry.cc:9
edm::one::OutputModuleBase::keptProducts
SelectedProductsForBranchType const & keptProducts() const
Definition: OutputModuleBase.h:96
helper
Definition: helper.py:1
edm::PoolOutputModule::writeProductDependencies
void writeProductDependencies()
Definition: PoolOutputModule.cc:323
edm::PoolOutputModule::DropDroppedPrior
Definition: PoolOutputModule.h:41
edm::PoolOutputModule::isFileOpen
bool isFileOpen() const override
Definition: PoolOutputModule.cc:329
edm::PoolOutputModule::logicalFileName_
const std::string logicalFileName_
Definition: PoolOutputModule.h:189
edm::PoolOutputModule::writeStoredMergeableRunProductMetadata
void writeStoredMergeableRunProductMetadata()
Definition: PoolOutputModule.cc:314
edm::PoolOutputModule::outputFileCount_
int outputFileCount_
Definition: PoolOutputModule.h:203
edm::PoolOutputModule::beginInputFile
void beginInputFile(FileBlock const &fb)
Definition: PoolOutputModule.cc:225
alignCSCRings.r
r
Definition: alignCSCRings.py:93
edm::PoolOutputModule::DropPrior
Definition: PoolOutputModule.h:41
edm::PoolOutputModule::fileName
std::string const & fileName() const
Definition: PoolOutputModule.h:46
edm::PoolOutputModule::writeProductDescriptionRegistry
void writeProductDescriptionRegistry()
Definition: PoolOutputModule.cc:319
edm::PoolOutputModule::writeBranchIDListRegistry
void writeBranchIDListRegistry()
Definition: PoolOutputModule.cc:321
edm::FileBlock::EventSelectionUsed
Definition: FileBlock.h:49
edm::PoolOutputModule::fillDependencyGraph
void fillDependencyGraph()
Definition: PoolOutputModule.cc:413
edm::FileBlock::DisabledInConfigFile
Definition: FileBlock.h:48
edm::PoolOutputModule::statusFileName_
std::string statusFileName_
Definition: PoolOutputModule.h:212
edm::PoolOutputModule::logicalFileName
std::string const & logicalFileName() const
Definition: PoolOutputModule.h:47
relativeConstraints.empty
bool empty
Definition: relativeConstraints.py:46
edm::PoolOutputModule::rootServiceChecker_
RootServiceChecker rootServiceChecker_
Definition: PoolOutputModule.h:184
Exception
Definition: hltDiff.cc:246
edm::PoolOutputModule::startEndFile
void startEndFile()
Definition: PoolOutputModule.cc:309
edm::BranchDescription::invalidBasketSize
static const int invalidBasketSize
Definition: BranchDescription.h:35
ParameterSetDescription
dqmiodatasetharvest.processes
processes
Definition: dqmiodatasetharvest.py:190
edm::PoolOutputModule::DropNone
Definition: PoolOutputModule.h:41
edm::PoolOutputModule::writeProcessHistoryRegistry
void writeProcessHistoryRegistry()
Definition: PoolOutputModule.cc:317
edm::PoolOutputModule::catalog_
const std::string catalog_
Definition: PoolOutputModule.h:190
edm::PoolOutputModule::dropMetaData_
DropMetaData dropMetaData_
Definition: PoolOutputModule.h:200
edm::PoolOutputModule::compressionLevel_
const int compressionLevel_
Definition: PoolOutputModule.h:192
edm::PoolOutputModule::treeMaxVirtualSize_
const int treeMaxVirtualSize_
Definition: PoolOutputModule.h:198
parents
TPRegexp parents
Definition: eve_filter.cc:21
hltrates_dqm_sourceclient-live_cfg.offset
offset
Definition: hltrates_dqm_sourceclient-live_cfg.py:78
edm::PoolOutputModule::writeFileIdentifier
void writeFileIdentifier()
Definition: PoolOutputModule.cc:312
child
Definition: simpleInheritance.h:11
edm::PoolOutputModule::finishEndFile
void finishEndFile()
Definition: PoolOutputModule.cc:324
edm::PoolOutputModule::DropAll
Definition: PoolOutputModule.h:41
edm::errors::Configuration
Definition: EDMException.h:36
class-composition.parent
parent
Definition: class-composition.py:88
edm::PoolOutputModule::childIndex_
unsigned int childIndex_
Definition: PoolOutputModule.h:205
SiStripBadComponentsDQMServiceTemplate_cfg.ep
ep
Definition: SiStripBadComponentsDQMServiceTemplate_cfg.py:86
edm::PoolOutputModule::basketOrder_
std::string basketOrder_
Definition: PoolOutputModule.h:197
benchmark_cfg.fb
fb
Definition: benchmark_cfg.py:14
edm::PoolOutputModule::writeParentageRegistry
void writeParentageRegistry()
Definition: PoolOutputModule.cc:320
edm::PoolOutputModule::fillDescription
static void fillDescription(ParameterSetDescription &desc)
Definition: PoolOutputModule.cc:428
edm::BranchChildren::insertChild
void insertChild(BranchID parent, BranchID child)
Definition: BranchChildren.cc:40
muonDTDigis_cfi.pset
pset
Definition: muonDTDigis_cfi.py:27
edm::PoolOutputModule::physicalAndLogicalNameForNewFile
virtual std::pair< std::string, std::string > physicalAndLogicalNameForNewFile()
Definition: PoolOutputModule.cc:332
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37
edm::PoolOutputModule::splitLevel
int const & splitLevel() const
Definition: PoolOutputModule.h:52