CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
evf::RecoEventOutputModuleForFU< Consumer > Class Template Reference

#include <RecoEventOutputModuleForFU.h>

Inheritance diagram for evf::RecoEventOutputModuleForFU< Consumer >:
edm::StreamerOutputModuleBase edm::OutputModule edm::EDConsumerBase

Public Member Functions

 RecoEventOutputModuleForFU (edm::ParameterSet const &ps)
 
virtual ~RecoEventOutputModuleForFU ()
 
- Public Member Functions inherited from edm::StreamerOutputModuleBase
 StreamerOutputModuleBase (ParameterSet const &ps)
 
virtual ~StreamerOutputModuleBase ()
 
- Public Member Functions inherited from edm::OutputModule
BranchChildren const & branchChildren () const
 
BranchIDLists const * branchIDLists () const
 
std::array< bool,
NumBranchTypes > const & 
hasNewlyDroppedBranch () const
 
SelectedProductsForBranchType
const & 
keptProducts () const
 
int maxEvents () const
 
OutputModuleoperator= (OutputModule const &)=delete
 
 OutputModule (ParameterSet const &pset)
 
 OutputModule (OutputModule const &)=delete
 
std::string const & processName () const
 
int remainingEvents () const
 
bool selected (BranchDescription const &desc) const
 
void selectProducts (ProductRegistry const &preg, ThinnedAssociationsHelper const &)
 
ThinnedAssociationsHelper const * thinnedAssociationsHelper () const
 
bool wantAllEvents () const
 
virtual ~OutputModule ()
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
 EDConsumerBase ()
 
ProductHolderIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
std::vector
< ProductHolderIndexAndSkipBit >
const & 
itemsToGetFromEvent () const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesDependentUpon (const std::string &iProcessName, std::vector< const char * > &oModuleLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
bool registeredToConsume (ProductHolderIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 
- Static Public Member Functions inherited from edm::StreamerOutputModuleBase
static void fillDescription (ParameterSetDescription &desc)
 
- Static Public Member Functions inherited from edm::OutputModule
static const std::string & baseType ()
 
static void fillDescription (ParameterSetDescription &desc)
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 

Private Member Functions

virtual void beginJob ()
 
virtual void beginLuminosityBlock (edm::LuminosityBlockPrincipal const &, edm::ModuleCallingContext const *)
 
virtual void doOutputEvent (EventMsgBuilder const &msg) const
 
virtual void doOutputHeader (InitMsgBuilder const &init_message) const
 
virtual void endLuminosityBlock (edm::LuminosityBlockPrincipal const &, edm::ModuleCallingContext const *)
 
virtual void start () const
 
virtual void stop () const
 

Private Attributes

IntJ accepted_
 
std::auto_ptr< Consumer > c_
 
IntJ errorEvents_
 
IntJ fileAdler32_
 
StringJ filelist_
 
IntJ filesize_
 
evf::FastMonitoringServicefms_
 
StringJ inputFiles_
 
boost::shared_ptr< FastMonitorjsonMonitor_
 
boost::filesystem::path openDatChecksumFilePath_
 
boost::filesystem::path openDatFilePath_
 
unsigned char * outBuf_ =0
 
DataPointDefinition outJsonDef_
 
IntJ processed_
 
bool readAdler32Check_ =false
 
IntJ retCodeMask_
 
std::string stream_label_
 
StringJ transferDestination_
 

Additional Inherited Members

- Public Types inherited from edm::OutputModule
typedef OutputModule ModuleType
 
- Protected Member Functions inherited from edm::OutputModule
void configure (OutputModuleDescription const &desc)
 
ModuleDescription const & description () const
 
void doBeginJob ()
 
bool doBeginLuminosityBlock (LuminosityBlockPrincipal const &lbp, EventSetup const &c, ModuleCallingContext const *mcc)
 
bool doBeginRun (RunPrincipal const &rp, EventSetup const &c, ModuleCallingContext const *mcc)
 
void doEndJob ()
 
bool doEndLuminosityBlock (LuminosityBlockPrincipal const &lbp, EventSetup const &c, ModuleCallingContext const *mcc)
 
bool doEndRun (RunPrincipal const &rp, EventSetup const &c, ModuleCallingContext const *mcc)
 
bool doEvent (EventPrincipal const &ep, EventSetup const &c, ActivityRegistry *act, ModuleCallingContext const *mcc)
 
void doPreallocate (PreallocationConfiguration const &)
 
std::map< BranchID::value_type,
BranchID::value_type > const & 
droppedBranchIDToKeptBranchID ()
 
Trig getTriggerResults (EventPrincipal const &ep, ModuleCallingContext const *) const
 
ModuleDescription const & moduleDescription () const
 
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
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, 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 ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 

Detailed Description

template<typename Consumer>
class evf::RecoEventOutputModuleForFU< Consumer >

Definition at line 25 of file RecoEventOutputModuleForFU.h.

Constructor & Destructor Documentation

template<typename Consumer >
evf::RecoEventOutputModuleForFU< Consumer >::RecoEventOutputModuleForFU ( edm::ParameterSet const &  ps)
explicit
Consumers are supposed to provide

void doOutputHeader(InitMsgBuilder const& init_message) void doOutputEvent(EventMsgBuilder const& msg) void start() void stop() static void fillDescription(ParameterSetDescription&)

Definition at line 74 of file RecoEventOutputModuleForFU.h.

References evf::RecoEventOutputModuleForFU< Consumer >::accepted_, jsoncollector::DataPointDefinition::addLegendItem(), ws_sso_content_reader::content, evf::RecoEventOutputModuleForFU< Consumer >::errorEvents_, edm::hlt::Exception, evf::RecoEventOutputModuleForFU< Consumer >::fileAdler32_, evf::RecoEventOutputModuleForFU< Consumer >::filelist_, evf::RecoEventOutputModuleForFU< Consumer >::filesize_, evf::RecoEventOutputModuleForFU< Consumer >::fms_, evf::RecoEventOutputModuleForFU< Consumer >::inputFiles_, evf::RecoEventOutputModuleForFU< Consumer >::jsonMonitor_, LogDebug, evf::RecoEventOutputModuleForFU< Consumer >::outJsonDef_, evf::RecoEventOutputModuleForFU< Consumer >::processed_, evf::RecoEventOutputModuleForFU< Consumer >::readAdler32Check_, evf::RecoEventOutputModuleForFU< Consumer >::retCodeMask_, cond::serialize(), jsoncollector::DataPointDefinition::setDefaultGroup(), jsoncollector::JsonMonitorable::setName(), contentValuesCheck::ss, evf::RecoEventOutputModuleForFU< Consumer >::stream_label_, AlCaHLTBitMon_QueryRunRegistry::string, SUM, and evf::RecoEventOutputModuleForFU< Consumer >::transferDestination_.

74  :
76  c_(new Consumer(ps)),
77  stream_label_(ps.getParameter<std::string>("@module_label")),
78  processed_(0),
79  accepted_(0),
80  errorEvents_(0),
81  retCodeMask_(0),
82  filelist_(),
83  filesize_(0),
84  inputFiles_(),
85  fileAdler32_(1),
87  outBuf_(new unsigned char[1024*1024])
88  {
89  std::string baseRunDir = edm::Service<evf::EvFDaqDirector>()->baseRunDir();
90  readAdler32Check_ = edm::Service<evf::EvFDaqDirector>()->outputAdler32Recheck();
91  LogDebug("RecoEventOutputModuleForFU") << "writing .dat files to -: " << baseRunDir;
92  // create open dir if not already there
93  edm::Service<evf::EvFDaqDirector>()->createRunOpendirMaybe();
94 
95  //replace hltOutoputA with stream if the HLT menu uses this convention
96  std::string testPrefix="hltOutput";
97  if (stream_label_.find(testPrefix)==0)
98  stream_label_=std::string("stream")+stream_label_.substr(testPrefix.size());
99 
100  if (stream_label_.find("_")!=std::string::npos) {
101  throw cms::Exception("RecoEventOutputModuleForFU")
102  << "Underscore character is reserved can not be used for stream names in FFF, but was detected in stream name -: " << stream_label_;
103  }
104 
105 
106  std::string stream_label_lo = stream_label_;
107  boost::algorithm::to_lower(stream_label_lo);
108  auto streampos = stream_label_lo.rfind("stream");
109  if (streampos !=0 && streampos!=std::string::npos)
110  throw cms::Exception("RecoEventOutputModuleForFU")
111  << "stream (case-insensitive) sequence was found in stream suffix. This is reserved and can not be used for names in FFF based HLT, but was detected in stream name";
112 
114 
115  processed_.setName("Processed");
116  accepted_.setName("Accepted");
117  errorEvents_.setName("ErrorEvents");
118  retCodeMask_.setName("ReturnCodeMask");
119  filelist_.setName("Filelist");
120  filesize_.setName("Filesize");
121  inputFiles_.setName("InputFiles");
122  fileAdler32_.setName("FileAdler32");
123  transferDestination_.setName("TransferDestination");
124 
126  outJsonDef_.addLegendItem("Processed","integer",DataPointDefinition::SUM);
127  outJsonDef_.addLegendItem("Accepted","integer",DataPointDefinition::SUM);
128  outJsonDef_.addLegendItem("ErrorEvents","integer",DataPointDefinition::SUM);
129  outJsonDef_.addLegendItem("ReturnCodeMask","integer",DataPointDefinition::BINARYOR);
130  outJsonDef_.addLegendItem("Filelist","string",DataPointDefinition::MERGE);
131  outJsonDef_.addLegendItem("Filesize","integer",DataPointDefinition::SUM);
132  outJsonDef_.addLegendItem("InputFiles","string",DataPointDefinition::CAT);
133  outJsonDef_.addLegendItem("FileAdler32","integer",DataPointDefinition::ADLER32);
134  outJsonDef_.addLegendItem("TransferDestination","string",DataPointDefinition::SAME);
135  std::stringstream tmpss,ss;
136  tmpss << baseRunDir << "/open/" << "output_" << getpid() << ".jsd";
137  ss << baseRunDir << "/" << "output_" << getpid() << ".jsd";
138  std::string outTmpJsonDefName = tmpss.str();
139  std::string outJsonDefName = ss.str();
140 
141  edm::Service<evf::EvFDaqDirector>()->lockInitLock();
142  struct stat fstat;
143  if (stat (outJsonDefName.c_str(), &fstat) != 0) { //file does not exist
144  LogDebug("RecoEventOutputModuleForFU") << "writing output definition file -: " << outJsonDefName;
147  FileIO::writeStringToFile(outTmpJsonDefName, content);
148  boost::filesystem::rename(outTmpJsonDefName,outJsonDefName);
149  }
150  edm::Service<evf::EvFDaqDirector>()->unlockInitLock();
151 
152  jsonMonitor_.reset(new FastMonitor(&outJsonDef_,true));
153  jsonMonitor_->setDefPath(outJsonDefName);
154  jsonMonitor_->registerGlobalMonitorable(&processed_,false);
155  jsonMonitor_->registerGlobalMonitorable(&accepted_,false);
156  jsonMonitor_->registerGlobalMonitorable(&errorEvents_,false);
157  jsonMonitor_->registerGlobalMonitorable(&retCodeMask_,false);
158  jsonMonitor_->registerGlobalMonitorable(&filelist_,false);
159  jsonMonitor_->registerGlobalMonitorable(&filesize_,false);
160  jsonMonitor_->registerGlobalMonitorable(&inputFiles_,false);
161  jsonMonitor_->registerGlobalMonitorable(&fileAdler32_,false);
162  jsonMonitor_->registerGlobalMonitorable(&transferDestination_,false);
163  jsonMonitor_->commit(nullptr);
164 
165  }
#define LogDebug(id)
void addLegendItem(std::string const &name, std::string const &type, std::string const &operation)
boost::shared_ptr< FastMonitor > jsonMonitor_
virtual void setName(std::string name)
#define SUM(A, B)
std::pair< Binary, Binary > serialize(const T &payload, bool packingOnly=false)
Definition: Serialization.h:92
void setDefaultGroup(std::string const &group)
template<typename Consumer >
evf::RecoEventOutputModuleForFU< Consumer >::~RecoEventOutputModuleForFU ( )
virtual

Definition at line 168 of file RecoEventOutputModuleForFU.h.

168 {}

Member Function Documentation

template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::beginJob ( void  )
privatevirtual

Reimplemented from edm::StreamerOutputModuleBase.

Definition at line 238 of file RecoEventOutputModuleForFU.h.

239  {
240  //get stream transfer destination
242  }
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::beginLuminosityBlock ( edm::LuminosityBlockPrincipal const &  ls,
edm::ModuleCallingContext const *   
)
privatevirtual

Reimplemented from edm::OutputModule.

Definition at line 246 of file RecoEventOutputModuleForFU.h.

References edm::LuminosityBlockPrincipal::luminosityBlock().

247  {
248  //edm::LogInfo("RecoEventOutputModuleForFU") << "begin lumi";
249  openDatFilePath_ = edm::Service<evf::EvFDaqDirector>()->getOpenDatFilePath(ls.luminosityBlock(),stream_label_);
250  openDatChecksumFilePath_ = edm::Service<evf::EvFDaqDirector>()->getOpenDatFilePath(ls.luminosityBlock(),stream_label_);
251  c_->setOutputFile(openDatFilePath_.string());
252  filelist_ = openDatFilePath_.filename().string();
253  }
def ls
Definition: eostools.py:346
boost::filesystem::path openDatChecksumFilePath_
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::doOutputEvent ( EventMsgBuilder const &  msg) const
privatevirtual

Implements edm::StreamerOutputModuleBase.

Definition at line 223 of file RecoEventOutputModuleForFU.h.

223  {
224  accepted_.value()++;
225  c_->doOutputEvent(msg); // You can't use msg in RecoEventOutputModuleForFU after this point
226  }
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::doOutputHeader ( InitMsgBuilder const &  init_message) const
privatevirtual

Implements edm::StreamerOutputModuleBase.

Definition at line 191 of file RecoEventOutputModuleForFU.h.

References cms::Adler32(), edm::hlt::Exception, alcazmumu_cfi::src, and AlCaHLTBitMon_QueryRunRegistry::string.

192  {
193  c_->doOutputHeader(init_message);
194 
195  const std::string openIniFileName = edm::Service<evf::EvFDaqDirector>()->getOpenInitFilePath(stream_label_);
196  struct stat istat;
197  stat(openIniFileName.c_str(), &istat);
198  //read back file to check integrity of what was written
199  off_t readInput=0;
200  uint32_t adlera=1,adlerb=0;
201  FILE *src = fopen(openIniFileName.c_str(),"r");
202  while (readInput<istat.st_size)
203  {
204  size_t toRead= readInput+1024*1024 < istat.st_size ? 1024*1024 : istat.st_size-readInput;
205  fread(outBuf_,toRead,1,src);
206  cms::Adler32((const char*)outBuf_,toRead,adlera,adlerb);
207  readInput+=toRead;
208  }
209  fclose(src);
210  uint32_t adler32c = (adlerb << 16) | adlera;
211  if (adler32c != c_->get_adler32_ini()) {
212  throw cms::Exception("RecoEventOutputModuleForFU") << "Checksum mismatch of ini file -: " << openIniFileName
213  << " expected:" << c_->get_adler32_ini() << " obtained:" << adler32c;
214  }
215  else {
216  edm::LogWarning("RecoEventOutputModuleForFU") << "Ini file checksum -: "<< stream_label_ << " " << adler32c;
217  boost::filesystem::rename(openIniFileName,edm::Service<evf::EvFDaqDirector>()->getInitFilePath(stream_label_));
218  }
219  }
void Adler32(char const *data, size_t len, uint32_t &a, uint32_t &b)
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::endLuminosityBlock ( edm::LuminosityBlockPrincipal const &  ls,
edm::ModuleCallingContext const *   
)
privatevirtual

Reimplemented from edm::OutputModule.

Definition at line 256 of file RecoEventOutputModuleForFU.h.

References cms::Adler32(), edm::hlt::Exception, edm::LuminosityBlockPrincipal::luminosityBlock(), NULL, alcazmumu_cfi::src, and AlCaHLTBitMon_QueryRunRegistry::string.

257  {
258  //edm::LogInfo("RecoEventOutputModuleForFU") << "end lumi";
259  long filesize=0;
260  fileAdler32_.value() = c_->get_adler32();
261  c_->closeOutputFile();
262  bool abortFlag = false;
263  processed_.value() = fms_->getEventsProcessedForLumi(ls.luminosityBlock(),&abortFlag);
264 
265  if (abortFlag) {
266  edm::LogInfo("RecoEventOutputModuleForFU") << "output suppressed";
267  return;
268  }
269 
270  if(processed_.value()!=0) {
271 
272  //lock
273  FILE *des = edm::Service<evf::EvFDaqDirector>()->maybeCreateAndLockFileHeadForStream(ls.luminosityBlock(),stream_label_);
274 
275  std::string deschecksum = edm::Service<evf::EvFDaqDirector>()->getMergedDatChecksumFilePath(ls.luminosityBlock(), stream_label_);
276 
277  struct stat istat;
278  FILE * cf = NULL;
279  uint32_t mergedAdler32=1;
280  //get adler32 accumulated checksum for the merged file
281  if (!stat(deschecksum.c_str(), &istat)) {
282  if (istat.st_size) {
283  cf = fopen(deschecksum.c_str(),"r");
284  if (!cf) throw cms::Exception("RecoEventOutputModuleForFU") << "Unable to open checksum file -: " << deschecksum.c_str();
285  fscanf(cf,"%u",&mergedAdler32);
286  fclose(cf);
287  }
288  else edm::LogWarning("RecoEventOutputModuleForFU") << "Checksum file size is empty -: "<< deschecksum.c_str();
289  }
290 
291  FILE *src = fopen(openDatFilePath_.string().c_str(),"r");
292 
293  stat(openDatFilePath_.string().c_str(), &istat);
294  off_t readInput=0;
295  uint32_t adlera=1;
296  uint32_t adlerb=0;
297  while (readInput<istat.st_size) {
298  size_t toRead= readInput+1024*1024 < istat.st_size ? 1024*1024 : istat.st_size-readInput;
299  fread(outBuf_,toRead,1,src);
300  fwrite(outBuf_,toRead,1,des);
301  if (readAdler32Check_)
302  cms::Adler32((const char*)outBuf_,toRead,adlera,adlerb);
303  readInput+=toRead;
304  filesize+=toRead;
305  }
306 
307  //if(des != 0 && src !=0){
308  // while((b=fgetc(src))!= EOF){
309  // fputc((unsigned char)b,des);
310  // filesize++;
311  // }
312  //}
313 
314  //write new string representation of the checksum value
315  cf = fopen(deschecksum.c_str(),"w");
316  if (!cf) throw cms::Exception("RecoEventOutputModuleForFU") << "Unable to open or rewind checksum file for writing -:" << deschecksum.c_str();
317 
318  //write adler32 combine to checksum file
319  mergedAdler32 = adler32_combine(mergedAdler32,fileAdler32_.value(),filesize);
320 
321  fprintf(cf,"%u",mergedAdler32);
322  fclose(cf);
323 
324  edm::Service<evf::EvFDaqDirector>()->unlockAndCloseMergeStream();
325  fclose(src);
326 
327  if (readAdler32Check_ && ((adlerb << 16) | adlera) != fileAdler32_.value()) {
328 
329  throw cms::Exception("RecoEventOutputModuleForFU") << "Adler32 checksum mismatch after reading file -: "
330  << openDatFilePath_.string() <<" in LS " << ls.luminosityBlock() << std::endl;
331  }
332 
333  } else {
334  //return if not in empty lumisectio mode
335  if (!edm::Service<evf::EvFDaqDirector>()->emptyLumisectionMode())
336  return;
337  filelist_ = "";
338  fileAdler32_.value()=-1;
339  }
340 
341  //remove file
342  remove(openDatFilePath_.string().c_str());
343  filesize_=filesize;
344 
345  jsonMonitor_->snap(ls.luminosityBlock());
346  const std::string outputJsonNameStream =
347  edm::Service<evf::EvFDaqDirector>()->getOutputJsonFilePath(ls.luminosityBlock(),stream_label_);
348  jsonMonitor_->outputFullJSON(outputJsonNameStream,ls.luminosityBlock());
349 
350  // reset monitoring params
351  accepted_.value() = 0;
352  filelist_ = "";
353  }
unsigned int getEventsProcessedForLumi(unsigned int lumi, bool *abortFlag=0)
def ls
Definition: eostools.py:346
#define NULL
Definition: scimark2.h:8
boost::shared_ptr< FastMonitor > jsonMonitor_
void Adler32(char const *data, size_t len, uint32_t &a, uint32_t &b)
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static

Definition at line 230 of file RecoEventOutputModuleForFU.h.

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

230  {
233  Consumer::fillDescription(desc);
234  descriptions.add("streamerOutput", desc);
235  }
static void fillDescription(ParameterSetDescription &desc)
void add(std::string const &label, ParameterSetDescription const &psetDescription)
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::start ( void  ) const
privatevirtual

Implements edm::StreamerOutputModuleBase.

Definition at line 172 of file RecoEventOutputModuleForFU.h.

References AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by progressbar.ProgressBar::__next__(), Types.LuminosityBlockRange::cppID(), and Types.EventRange::cppID().

173  {
174  const std::string openInitFileName = edm::Service<evf::EvFDaqDirector>()->getOpenInitFilePath(stream_label_);
175  edm::LogInfo("RecoEventOutputModuleForFU") << "start() method, initializing streams. init stream -: "
176  << openInitFileName;
177  c_->setInitMessageFile(openInitFileName);
178  c_->start();
179 
180  }
template<typename Consumer >
void evf::RecoEventOutputModuleForFU< Consumer >::stop ( ) const
privatevirtual

Implements edm::StreamerOutputModuleBase.

Definition at line 184 of file RecoEventOutputModuleForFU.h.

185  {
186  c_->stop();
187  }

Member Data Documentation

template<typename Consumer >
IntJ evf::RecoEventOutputModuleForFU< Consumer >::accepted_
mutableprivate
template<typename Consumer >
std::auto_ptr<Consumer> evf::RecoEventOutputModuleForFU< Consumer >::c_
private

Definition at line 51 of file RecoEventOutputModuleForFU.h.

template<typename Consumer >
IntJ evf::RecoEventOutputModuleForFU< Consumer >::errorEvents_
private
template<typename Consumer >
IntJ evf::RecoEventOutputModuleForFU< Consumer >::fileAdler32_
private
template<typename Consumer >
StringJ evf::RecoEventOutputModuleForFU< Consumer >::filelist_
private
template<typename Consumer >
IntJ evf::RecoEventOutputModuleForFU< Consumer >::filesize_
private
template<typename Consumer >
evf::FastMonitoringService* evf::RecoEventOutputModuleForFU< Consumer >::fms_
private
template<typename Consumer >
StringJ evf::RecoEventOutputModuleForFU< Consumer >::inputFiles_
private
template<typename Consumer >
boost::shared_ptr<FastMonitor> evf::RecoEventOutputModuleForFU< Consumer >::jsonMonitor_
private
template<typename Consumer >
boost::filesystem::path evf::RecoEventOutputModuleForFU< Consumer >::openDatChecksumFilePath_
private

Definition at line 54 of file RecoEventOutputModuleForFU.h.

template<typename Consumer >
boost::filesystem::path evf::RecoEventOutputModuleForFU< Consumer >::openDatFilePath_
private

Definition at line 53 of file RecoEventOutputModuleForFU.h.

template<typename Consumer >
unsigned char* evf::RecoEventOutputModuleForFU< Consumer >::outBuf_ =0
private

Definition at line 67 of file RecoEventOutputModuleForFU.h.

template<typename Consumer >
DataPointDefinition evf::RecoEventOutputModuleForFU< Consumer >::outJsonDef_
private
template<typename Consumer >
IntJ evf::RecoEventOutputModuleForFU< Consumer >::processed_
private
template<typename Consumer >
bool evf::RecoEventOutputModuleForFU< Consumer >::readAdler32Check_ =false
private
template<typename Consumer >
IntJ evf::RecoEventOutputModuleForFU< Consumer >::retCodeMask_
private
template<typename Consumer >
std::string evf::RecoEventOutputModuleForFU< Consumer >::stream_label_
private
template<typename Consumer >
StringJ evf::RecoEventOutputModuleForFU< Consumer >::transferDestination_
private