7 #ifndef __EPICS_METRIC__
8 #define __EPICS_METRIC__ 1
10 #include "artdaq-utilities/Plugins/MetricMacros.hh"
11 #include "messagefacility/MessageLogger/MessageLogger.h"
12 #include <unordered_map>
16 #pragma clang diagnostic push
17 #pragma clang diagnostic ignored "-Wunused-parameter"
21 #pragma clang diagnostic pop
36 std::unordered_map<std::string, chid> channels_;
38 bool checkChannel_(std::string name)
40 if (!channels_.count(name))
43 ca_search(name.c_str(), &channel);
44 auto sts = ca_pend_io(5.0);
45 if (sts != ECA_NORMAL)
47 SEVCHK(ca_clear_channel(channel), NULL);
48 mf::LogWarning(
"EPICS Plugin") <<
"Channel " << name <<
" not found!";
49 channels_[name] =
nullptr;
52 channels_[name] = channel;
55 return channels_[name] !=
nullptr;
64 explicit EpicsMetric(fhicl::ParameterSet
const& pset, std::string
const& app_name)
66 , prefix_(pset.get<std::string>(
"channel_name_prefix",
"artdaq"))
71 MetricPlugin::stopMetrics();
78 std::string
getLibName()
const override {
return "epics"; }
85 for (
auto channel : channels_)
87 SEVCHK(ca_clear_channel(channel.second), NULL);
107 void sendMetric_(
const std::string& name,
const std::string& value,
const std::string& unit)
override
109 std::string caName = prefix_ +
":" + name;
110 std::string tmpValue = value +
" " + unit;
112 if (checkChannel_(caName))
115 if (tmpValue.size() > 40) { tmpValue = tmpValue.erase(40); }
116 SEVCHK(ca_put(DBR_STRING, channels_[caName], tmpValue.c_str()), NULL);
117 SEVCHK(ca_flush_io(), NULL);
131 void sendMetric_(
const std::string& name,
const int& value,
const std::string& unit)
override
134 std::string caName = prefix_ +
":" + name;
137 mf::LogDebug(
"EPICS Plugin") <<
"Not sure if I can send ChannelAccess Units...configure in db instead.";
140 if (checkChannel_(caName))
142 dbr_long_t val =
static_cast<dbr_long_t
>(value);
143 SEVCHK(ca_put(DBR_LONG, channels_[caName], &val), NULL);
144 SEVCHK(ca_flush_io(), NULL);
158 void sendMetric_(
const std::string& name,
const double& value,
const std::string& unit)
override
161 std::string caName = prefix_ +
":" + name;
164 mf::LogDebug(
"EPICS Plugin") <<
"Not sure if I can send ChannelAccess Units...configure in db instead.";
167 if (checkChannel_(caName))
169 dbr_double_t val =
static_cast<dbr_double_t
>(value);
170 SEVCHK(ca_put(DBR_DOUBLE, channels_[caName], &val), NULL);
171 SEVCHK(ca_flush_io(), NULL);
185 void sendMetric_(
const std::string& name,
const float& value,
const std::string& unit)
override
188 std::string caName = prefix_ +
":" + name;
191 mf::LogDebug(
"EPICS Plugin") <<
"Not sure if I can send ChannelAccess Units...configure in db instead.";
194 if (checkChannel_(caName))
196 dbr_float_t val =
static_cast<dbr_float_t
>(value);
197 SEVCHK(ca_put(DBR_FLOAT, channels_[caName], &val), NULL);
198 SEVCHK(ca_flush_io(), NULL);
212 void sendMetric_(
const std::string& name,
const unsigned long int& value,
const std::string& unit)
override
215 std::string caName = prefix_ +
":" + name;
218 mf::LogDebug(
"EPICS Plugin") <<
"Not sure if I can send ChannelAccess Units...configure in db instead.";
221 if (checkChannel_(caName))
223 dbr_ulong_t val =
static_cast<dbr_ulong_t
>(value);
224 SEVCHK(ca_put(DBR_LONG, channels_[caName], &val), NULL);
225 SEVCHK(ca_flush_io(), NULL);
233 #endif //End ifndef __EPICS_METRIC__
void sendMetric_(const std::string &name, const float &value, const std::string &unit) override
Send a float metric data point to ChannelAccess.
void sendMetric_(const std::string &name, const unsigned long int &value, const std::string &unit) override
Send an unsigned integer metric data point to ChannelAccess.
An instance of the MetricPlugin class that sends metric data using the Channel Access protocol from E...
void stopMetrics_() override
Clears the registered ChannelAccess channels.
void startMetrics_() override
No initialization is needed to start sending metrics.
std::string getLibName() const override
Gets the unique library name of this plugin.
void sendMetric_(const std::string &name, const std::string &value, const std::string &unit) override
Send a string metric data point to ChannelAccess.
EpicsMetric(fhicl::ParameterSet const &pset, std::string const &app_name)
Construct an instance of the EpicsMetric plugin.
void sendMetric_(const std::string &name, const double &value, const std::string &unit) override
Send a double metric data point to ChannelAccess.
void sendMetric_(const std::string &name, const int &value, const std::string &unit) override
Send an integer metric data point to ChannelAccess.