1 #include "artdaq/Application/DataLoggerApp.hh"
2 #include "artdaq/Application/DataLoggerCore.hh"
3 #include "artdaq-core/Utilities/ExceptionHandler.hh"
20 if (DataLogger_ptr_.get() == 0)
24 external_request_status_ = DataLogger_ptr_->initialize(pset);
25 if (!external_request_status_)
27 report_string_ =
"Error initializing ";
28 report_string_.append(app_name +
" ");
29 report_string_.append(
"with ParameterSet = \"" + pset.to_string() +
"\".");
32 return external_request_status_;
38 external_request_status_ = DataLogger_ptr_->start(
id);
39 if (!external_request_status_)
41 report_string_ =
"Error starting ";
42 report_string_.append(app_name +
" ");
43 report_string_.append(
"for run number ");
44 report_string_.append(boost::lexical_cast<std::string>(
id.run()));
45 report_string_.append(
".");
48 return external_request_status_;
54 external_request_status_ = DataLogger_ptr_->stop();
55 if (!external_request_status_)
57 report_string_ =
"Error stopping ";
58 report_string_.append(app_name +
".");
61 return external_request_status_;
67 external_request_status_ = DataLogger_ptr_->pause();
68 if (!external_request_status_)
70 report_string_ =
"Error pausing ";
71 report_string_.append(app_name +
".");
74 return external_request_status_;
80 external_request_status_ = DataLogger_ptr_->resume();
81 if (!external_request_status_)
83 report_string_ =
"Error resuming ";
84 report_string_.append(app_name +
".");
87 return external_request_status_;
93 external_request_status_ = DataLogger_ptr_->shutdown();
94 if (!external_request_status_)
96 report_string_ =
"Error shutting down ";
97 report_string_.append(app_name +
".");
100 return external_request_status_;
115 std::string resultString;
118 if (which ==
"transition_status")
120 if (report_string_.length() > 0) {
return report_string_; }
121 else {
return "Success"; }
133 if (DataLogger_ptr_.get() != 0)
135 resultString.append(DataLogger_ptr_->report(which));
139 resultString.append(
"This DataLogger has not yet been initialized and ");
140 resultString.append(
"therefore can not provide reporting.");
bool do_initialize(fhicl::ParameterSet const &pset, uint64_t, uint64_t) override
Initialize the DataLoggerCore.
DataLoggerApp()
DataLoggerApp Constructor.
bool do_shutdown(uint64_t) override
Shutdown the DataLoggerCore.
bool do_soft_initialize(fhicl::ParameterSet const &, uint64_t, uint64_t) override
Soft-initialize the DataLoggerCore. No-Op.
bool do_resume(uint64_t, uint64_t) override
Resume the DataLoggerCore.
bool do_pause(uint64_t, uint64_t) override
Pause the DataLoggerCore.
std::string report(std::string const &which) const override
If which is "transition_status", report the status of the last transition. Otherwise pass through to ...
bool do_reinitialize(fhicl::ParameterSet const &, uint64_t, uint64_t) override
Reinitialize the DataLoggerCore. No-Op.
bool do_start(art::RunID id, uint64_t, uint64_t) override
Start the DataLoggerCore.
bool do_stop(uint64_t, uint64_t) override
Stop the DataLoggerCore.
DataLoggerCore implements the state machine for the DataLogger artdaq application. DataLoggerCore processes incoming events in one of three roles: Data Logger, Online Monitor, or Dispatcher.