1 #include "artdaq/Application/DataLoggerApp.hh"
2 #include "artdaq/Application/DataLoggerCore.hh"
3 #include "artdaq-core/Utilities/ExceptionHandler.hh"
22 if (DataLogger_ptr_.get() == 0)
26 external_request_status_ = DataLogger_ptr_->initialize(pset);
27 if (!external_request_status_)
29 report_string_ =
"Error initializing ";
30 report_string_.append(app_name +
" ");
31 report_string_.append(
"with ParameterSet = \"" + pset.to_string() +
"\".");
34 return external_request_status_;
40 external_request_status_ = DataLogger_ptr_->start(
id);
41 if (!external_request_status_)
43 report_string_ =
"Error starting ";
44 report_string_.append(app_name +
" ");
45 report_string_.append(
"for run number ");
46 report_string_.append(boost::lexical_cast<std::string>(
id.run()));
47 report_string_.append(
".");
50 return external_request_status_;
56 external_request_status_ = DataLogger_ptr_->stop();
57 if (!external_request_status_)
59 report_string_ =
"Error stopping ";
60 report_string_.append(app_name +
".");
63 return external_request_status_;
69 external_request_status_ = DataLogger_ptr_->pause();
70 if (!external_request_status_)
72 report_string_ =
"Error pausing ";
73 report_string_.append(app_name +
".");
76 return external_request_status_;
82 external_request_status_ = DataLogger_ptr_->resume();
83 if (!external_request_status_)
85 report_string_ =
"Error resuming ";
86 report_string_.append(app_name +
".");
89 return external_request_status_;
95 external_request_status_ = DataLogger_ptr_->shutdown();
96 if (!external_request_status_)
98 report_string_ =
"Error shutting down ";
99 report_string_.append(app_name +
".");
102 return external_request_status_;
117 std::string resultString;
120 if (which ==
"transition_status")
122 if (report_string_.length() > 0) {
return report_string_; }
123 else {
return "Success"; }
135 if (DataLogger_ptr_.get() != 0)
137 resultString.append(DataLogger_ptr_->report(which));
141 resultString.append(
"This DataLogger has not yet been initialized and ");
142 resultString.append(
"therefore can not provide reporting.");
bool do_initialize(fhicl::ParameterSet const &pset, uint64_t, uint64_t) override
Initialize the DataLoggerCore.
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.
DataLoggerApp(int rank, std::string name)
DataLoggerApp Constructor.
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.