CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Attributes
edm::InputFile Class Reference

#include <InputFile.h>

Public Member Functions

void Close ()
 
void eventReadFromFile () const
 
TObject * Get (char const *name)
 
TFileCacheRead * GetCacheRead () const
 
 InputFile (char const *fileName, char const *msg, InputType inputType)
 
 InputFile (InputFile const &)=delete
 
void inputFileOpened (std::string const &logicalFileName, std::string const &inputType, std::string const &moduleName, std::string const &label, std::string const &fid, std::vector< std::string > const &branchNames)
 
void logFileAction (char const *msg, char const *fileName) const
 
InputFileoperator= (InputFile const &)=delete
 
void reportInputLumiSection (unsigned int run, unsigned int lumi) const
 
void reportInputRunNumber (unsigned int run) const
 
void SetCacheRead (TFileCacheRead *tfcr)
 
 ~InputFile ()
 

Static Public Member Functions

static void reportFallbackAttempt (std::string const &pfn, std::string const &logicalFileName, std::string const &errorMessage)
 
static void reportReadBranch (InputType inputType, std::string const &branchname)
 
static void reportReadBranches ()
 
static void reportSkippedFile (std::string const &fileName, std::string const &logicalFileName)
 

Private Attributes

edm::propagate_const< std::unique_ptr< TFile > > file_
 
std::string fileName_
 
InputType inputType_
 
JobReport::Token reportToken_
 

Detailed Description

Definition at line 21 of file InputFile.h.

Constructor & Destructor Documentation

InputFile::InputFile ( char const *  fileName,
char const *  msg,
InputType  inputType 
)
explicit

Definition at line 18 of file InputFile.cc.

References MillePedeFileConverter_cfg::e, file_, edm::threadLocalException::getException(), logFileAction(), and edm::threadLocalException::setException().

18  :
19  file_(), fileName_(fileName), reportToken_(0), inputType_(inputType) {
20 
22  {
23  // ROOT's context management implicitly assumes that a file is opened and
24  // closed on the same thread. To avoid the problem, we declare a local
25  // TContext object; when it goes out of scope, its destructor unregisters
26  // the context, guaranteeing the context is unregistered in the same thread
27  // it was registered in. Fixes issue #15524.
28  TDirectory::TContext contextEraser;
29 
30  file_ = std::unique_ptr<TFile>(TFile::Open(fileName)); // propagate_const<T> has no reset() function
31  }
32  std::exception_ptr e = edm::threadLocalException::getException();
33  if(e != std::exception_ptr()) {
34  edm::threadLocalException::setException(std::exception_ptr());
35  std::rethrow_exception(e);
36  }
37  if(!file_) {
38  return;
39  }
40  if(file_->IsZombie()) {
41  file_ = nullptr; // propagate_const<T> has no reset() function
42  return;
43  }
44 
45  logFileAction(" Successfully opened file ", fileName);
46  }
JobReport::Token reportToken_
Definition: InputFile.h:53
InputType inputType_
Definition: InputFile.h:54
void logFileAction(char const *msg, char const *fileName) const
Definition: InputFile.cc:116
edm::propagate_const< std::unique_ptr< TFile > > file_
Definition: InputFile.h:51
std::string fileName_
Definition: InputFile.h:52
void setException(std::exception_ptr e)
std::exception_ptr getException()
InputFile::~InputFile ( )

Definition at line 48 of file InputFile.cc.

References Close().

48  {
49  Close();
50  }
edm::InputFile::InputFile ( InputFile const &  )
delete

Member Function Documentation

void InputFile::Close ( )

Definition at line 101 of file InputFile.cc.

References cppFunctionSkipper::exception, file_, fileName_, inputType_, logFileAction(), and reportToken_.

Referenced by ~InputFile().

101  {
102  if(file_->IsOpen()) {
103  file_->Close();
104  try {
105  logFileAction(" Closed file ", fileName_.c_str());
106  Service<JobReport> reportSvc;
107  reportSvc->inputFileClosed(inputType_, reportToken_);
108  } catch(std::exception) {
109  // If Close() called in a destructor after an exception throw, the services may no longer be active.
110  // Therefore, we catch any reasonable new exception.
111  }
112  }
113  }
JobReport::Token reportToken_
Definition: InputFile.h:53
InputType inputType_
Definition: InputFile.h:54
void logFileAction(char const *msg, char const *fileName) const
Definition: InputFile.cc:116
edm::propagate_const< std::unique_ptr< TFile > > file_
Definition: InputFile.h:51
std::string fileName_
Definition: InputFile.h:52
void InputFile::eventReadFromFile ( ) const

Definition at line 71 of file InputFile.cc.

References inputType_, and reportToken_.

71  {
72  Service<JobReport> reportSvc;
73  reportSvc->eventReadFromFile(inputType_, reportToken_);
74  }
JobReport::Token reportToken_
Definition: InputFile.h:53
InputType inputType_
Definition: InputFile.h:54
TObject* edm::InputFile::Get ( char const *  name)
inline

Definition at line 46 of file InputFile.h.

References file_.

46 {return file_->Get(name);}
edm::propagate_const< std::unique_ptr< TFile > > file_
Definition: InputFile.h:51
TFileCacheRead* edm::InputFile::GetCacheRead ( ) const
inline

Definition at line 47 of file InputFile.h.

References file_.

Referenced by edm::roottree::trainCache().

47 {return file_->GetCacheRead();}
edm::propagate_const< std::unique_ptr< TFile > > file_
Definition: InputFile.h:51
void InputFile::inputFileOpened ( std::string const &  logicalFileName,
std::string const &  inputType,
std::string const &  moduleName,
std::string const &  label,
std::string const &  fid,
std::vector< std::string > const &  branchNames 
)

Definition at line 53 of file InputFile.cc.

References fileName_, reportToken_, and AlCaHLTBitMon_QueryRunRegistry::string.

58  {
59  Service<JobReport> reportSvc;
60  reportToken_ = reportSvc->inputFileOpened(fileName_,
61  logicalFileName,
62  std::string(),
63  inputType,
64  moduleName,
65  label,
66  fid,
67  branchNames);
68  }
JobReport::Token reportToken_
Definition: InputFile.h:53
std::string moduleName(Provenance const &provenance)
Definition: Provenance.cc:27
std::string fileName_
Definition: InputFile.h:52
void InputFile::logFileAction ( char const *  msg,
char const *  fileName 
) const

Definition at line 116 of file InputFile.cc.

References MillePedeFileConverter_cfg::fileName, and edm::FlushMessageLog().

Referenced by Close(), InputFile(), and SetCacheRead().

116  {
117  LogAbsolute("fileAction") << std::setprecision(0) << TimeOfDay() << msg << fileName;
118  FlushMessageLog();
119  }
void FlushMessageLog()
InputFile& edm::InputFile::operator= ( InputFile const &  )
delete
void InputFile::reportFallbackAttempt ( std::string const &  pfn,
std::string const &  logicalFileName,
std::string const &  errorMessage 
)
static

Definition at line 95 of file InputFile.cc.

Referenced by edm::RootInputFileSequence::initTheFile().

95  {
96  Service<JobReport> reportSvc;
97  reportSvc->reportFallbackAttempt(pfn, logicalFileName, errorMessage);
98  }
void InputFile::reportInputLumiSection ( unsigned int  run,
unsigned int  lumi 
) const

Definition at line 83 of file InputFile.cc.

83  {
84  Service<JobReport> reportSvc;
85  reportSvc->reportInputLumiSection(run, lumi);
86  }
void InputFile::reportInputRunNumber ( unsigned int  run) const

Definition at line 77 of file InputFile.cc.

77  {
78  Service<JobReport> reportSvc;
79  reportSvc->reportInputRunNumber(run);
80  }
void InputFile::reportReadBranch ( InputType  inputType,
std::string const &  branchname 
)
static

Definition at line 128 of file InputFile.cc.

Referenced by edm::RootDelayedReader::getProduct_().

128  {
129  Service<JobReport> reportSvc;
130  reportSvc->reportReadBranch(inputType, branchName);
131  }
void InputFile::reportReadBranches ( )
static

Definition at line 122 of file InputFile.cc.

Referenced by edm::EmbeddedRootSource::endJob(), and edm::PoolSource::endJob().

122  {
123  Service<JobReport> reportSvc;
124  reportSvc->reportReadBranches();
125  }
void InputFile::reportSkippedFile ( std::string const &  fileName,
std::string const &  logicalFileName 
)
static

Definition at line 89 of file InputFile.cc.

Referenced by edm::RootInputFileSequence::initTheFile().

89  {
90  Service<JobReport> reportSvc;
91  reportSvc->reportSkippedFile(fileName, logicalFileName);
92  }
void edm::InputFile::SetCacheRead ( TFileCacheRead *  tfcr)
inline

Definition at line 48 of file InputFile.h.

References file_, logFileAction(), and NULL.

Referenced by edm::roottree::trainCache().

48 {file_->SetCacheRead(tfcr, NULL, TFile::kDoNotDisconnect);}
#define NULL
Definition: scimark2.h:8
edm::propagate_const< std::unique_ptr< TFile > > file_
Definition: InputFile.h:51

Member Data Documentation

edm::propagate_const<std::unique_ptr<TFile> > edm::InputFile::file_
private

Definition at line 51 of file InputFile.h.

Referenced by Close(), Get(), GetCacheRead(), InputFile(), and SetCacheRead().

std::string edm::InputFile::fileName_
private

Definition at line 52 of file InputFile.h.

Referenced by Close(), and inputFileOpened().

InputType edm::InputFile::inputType_
private

Definition at line 54 of file InputFile.h.

Referenced by Close(), and eventReadFromFile().

JobReport::Token edm::InputFile::reportToken_
private

Definition at line 53 of file InputFile.h.

Referenced by Close(), eventReadFromFile(), and inputFileOpened().