1 #include "artdaq/DAQdata/Globals.hh"
2 #define TRACE_NAME (app_name + "_DataLoggerApp").c_str()
4 #include "artdaq-core/Utilities/ExceptionHandler.hh"
5 #include "artdaq/Application/DataLoggerApp.hh"
6 #include "artdaq/Application/DataLoggerCore.hh"
22 if (DataLogger_ptr_ ==
nullptr)
24 DataLogger_ptr_ = std::make_unique<DataLoggerCore>();
31 report_string_.append(
"with ParameterSet = \"" + pset.to_string() +
"\".");
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_; }
136 if (DataLogger_ptr_ !=
nullptr)
138 resultString.append(DataLogger_ptr_->report(which));
142 resultString.append(
"This DataLogger has not yet been initialized and ");
143 resultString.append(
"therefore can not provide reporting.");
152 external_request_status_ = DataLogger_ptr_->add_config_archive_entry(key, value);
153 if (!external_request_status_)
155 report_string_ =
"Error adding config entry with key ";
156 report_string_.append(key +
" and value \"");
157 report_string_.append(value +
"\" in");
158 report_string_.append(app_name +
".");
161 return external_request_status_;
167 external_request_status_ = DataLogger_ptr_->clear_config_archive();
168 if (!external_request_status_)
170 report_string_ =
"Error clearing the configuration archive in ";
171 report_string_.append(app_name +
".");
174 return external_request_status_;
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 external_request_status_
Whether the last command succeeded.
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.
std::string report_string_
Status information about the last command.
bool do_clear_config_archive() override
Clear the configuration archive list in the DataLoggerCore.
bool do_start(art::RunID id, uint64_t, uint64_t) override
Start the DataLoggerCore.
bool do_add_config_archive_entry(std::string const &, std::string const &) override
Add the specified configuration archive entry to the DataLoggerCore.
bool do_stop(uint64_t, uint64_t) override
Stop the DataLoggerCore.