18 m_file = TFile::Open(filename.c_str());
26 std::shared_ptr<GenRunInfo> ri = std::make_shared<GenRunInfo>();
41 for (
int nn = n; nn > 0; --nn)
54 TKey *key = (TKey*) (*
m_next)();
61 const char *cl = key->GetClassName();
64 size_t geneventdata30 = strncmp(cl,
"HepMC::GenEventData", 19);
65 size_t geneventdata31 = strncmp(cl,
"HepMC3::GenEventData", 20);
66 if ( geneventdata31 == 0 || geneventdata30 == 0 ) {
67 if (geneventdata30 == 0) {
68 HEPMC3_WARNING_LEVEL(900,
"ReaderRoot::read_event: The object was written with HepMC3 version 3.0")
#define HEPMC3_WARNING_LEVEL(LEVEL, MESSAGE)
Macro for printing HEPMC3_HEPMC3_WARNING messages.
#define HEPMC3_ERROR_LEVEL(LEVEL, MESSAGE)
Macro for printing error messages.
Definition of class ReaderRoot.
Declaration of the Verrion functions and some macros.
Stores event-related information.
void set_run_info(std::shared_ptr< GenRunInfo > run)
Set the GenRunInfo object by smart pointer.
void read_data(const GenEventData &data)
Fill GenEvent based on GenEventData.
void clear()
Remove contents of this event.
GenEvent I/O parsing and serialization for root files.
bool read_event(GenEvent &evt) override
Read event from file.
bool failed() override
Get stream error state.
bool skip(const int) override
skip events
void close() override
Close file stream.
ReaderRoot(const std::string &filename)
Default constructor.
TFile * m_file
File handler.
TIter * m_next
Iterator for event reading.
virtual void set_run_info(std::shared_ptr< GenRunInfo > run)
Set the global GenRunInfo object.
virtual std::shared_ptr< GenRunInfo > run_info() const
Get the global GenRunInfo object.
Stores serializable event information.
Stores serializable run information.