29 namespace fs = std::filesystem;
38 topNodeName(topnodename),
42 event_header(nullptr),
44 trig_hit_vec(nullptr),
66 runNode->
addNode(runHeaderNode);
74 eventNode->
addNode(eventHeaderNode);
82 eventNode->
addNode(triggerhitNode);
130 for (
size_t i = 0; i <
elementIDs->size(); ++i) {
156 std::cout <<
"Closing currently open file "
158 <<
" and opening " << filenam << std::endl;
164 std::cout <<
"Attempting to open file: " << std::filesystem::absolute(filenam) << std::endl;
166 if (!std::filesystem::exists(filenam)) {
167 std::cerr <<
"!!ERROR!! File does not exist: " << filenam << std::endl;
172 std::cout <<
ThisName <<
": opening file " <<
filename.c_str() << std::endl;
177 _fin = TFile::Open(filenam.c_str(),
"READ");
179 std::cerr <<
"!!ERROR!! Failed to open file " << filenam << std::endl;
185 std::cerr <<
"!!ERROR!! Tree " <<
_tree_name <<
" not found in file " << filenam << std::endl;
217 std::cout <<
Name() <<
": No Input file open" << std::endl;
222 std::cout <<
Name() <<
": No Input file from filelist opened" << std::endl;
229 std::cout <<
"Getting Event from " <<
Name() << std::endl;
269 cout <<
Name() <<
": fileclose: No Input file open" << endl;
303 list<string>::const_iterator iter =
filelist.begin();
306 cout <<
PHWHERE <<
" opening next file: " << *iter << endl;
310 cout <<
PHWHERE <<
" could not open file: " << *iter << endl;
324 cerr <<
"!!ERROR!! PushBackEvents(): Not implemented yet." << endl;
404 cout <<
PHWHERE <<
Name() <<
" No MasterSync object, cannot perform synchronization" << endl;
405 cout <<
"Most likely your first file does not contain a SyncObject and the file" << endl;
406 cout <<
"opened by the Fun4AllDstInputManager with Name " <<
Name() <<
" has one" << endl;
407 cout <<
"Change your macro and use the file opened by this input manager as first input" << endl;
408 cout <<
"and you will be okay. Fun4All will not process the current configuration" << endl << endl;
414 cout <<
"big problem" << endl;
int verbosity
The verbosity level. 0 means not verbose at all.
virtual const std::string Name() const
Returns the name of this module.
static Fun4AllServer * instance()
PHCompositeNode * topNode() const
void CurrentEvent(const int evt)
void SegmentNumber(const int iseg)
void PrdfEvents(const int i)
PHBoolean addNode(PHNode *)
PHNode * findFirst(const std::string &, const std::string &)
virtual void set_data_quality(const int a)=0
virtual void set_spill_id(const int a)=0
virtual void set_event_id(const int a)=0
virtual void set_qie_rf_intensity(const short i, const int a)=0
virtual void set_run_id(const int a)=0
virtual void set_trigger(const SQEvent::TriggerMask i, const bool a)=0
virtual void push_back(const SQHit *hit)=0
An SQ interface class to hold one detector hit.
virtual void set_element_id(const short a)
virtual void set_hit_id(const int a)
virtual void set_detector_id(const short a)
virtual void set_tdc_time(const float a)
virtual void set_drift_distance(const float a)
virtual void set_in_time(const bool a)
virtual void set_n_spill(const int a)
virtual const SQSpill * get(unsigned int idkey) const
Return the SQSpill entry having spill ID = 'idkey'. Return '0' if no entry exists.
virtual SQSpill * insert(const SQSpill *hit)
Insert the given SQSpill object.
virtual size_t size() const
Return the number of spills held.
An SQ interface class to hold the data of one spill.
virtual void set_spill_id(const int a)
virtual void set_run_id(const int a)
virtual int Different(const SyncObject *other) const
virtual void SegmentNumber(const int)
set Segment Number
virtual void Reset()
Clear Sync.
virtual void EventNumber(const int)
set Event Number
virtual SyncObject * clone() const
Virtual copy constructor.
virtual void EventCounter(const int)
set Event Counter
virtual void RunNumber(const int)
set Run Number