From cacc168520f742ae7a45fa4d7198d6958ae5b9a4 Mon Sep 17 00:00:00 2001 From: Alan Conway Date: Thu, 22 Jan 2009 19:24:31 +0000 Subject: More latency metrics. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@736752 13f79535-47bb-0310-9956-ffa450edef68 --- cpp/src/qpid/sys/LatencyMetric.cpp | 4 ++++ cpp/src/qpid/sys/LatencyMetric.h | 9 ++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) (limited to 'cpp/src/qpid/sys') diff --git a/cpp/src/qpid/sys/LatencyMetric.cpp b/cpp/src/qpid/sys/LatencyMetric.cpp index 6a52425706..caa221def4 100644 --- a/cpp/src/qpid/sys/LatencyMetric.cpp +++ b/cpp/src/qpid/sys/LatencyMetric.cpp @@ -32,6 +32,10 @@ void LatencyMetricTimestamp::initialize(const LatencyMetricTimestamp& ts) { const_cast(ts.latency_metric_timestamp) = Duration(now()); } +void LatencyMetricTimestamp::clear(const LatencyMetricTimestamp& ts) { + const_cast(ts.latency_metric_timestamp) = 0; +} + LatencyMetric::LatencyMetric(const char* msg, int64_t skip_) : message(msg), count(0), total(0), skipped(0), skip(skip_) {} diff --git a/cpp/src/qpid/sys/LatencyMetric.h b/cpp/src/qpid/sys/LatencyMetric.h index ff679ef6a8..63b5020db4 100644 --- a/cpp/src/qpid/sys/LatencyMetric.h +++ b/cpp/src/qpid/sys/LatencyMetric.h @@ -33,6 +33,7 @@ namespace sys { struct LatencyMetricTimestamp { LatencyMetricTimestamp() : latency_metric_timestamp(0) {} static void initialize(const LatencyMetricTimestamp&); + static void clear(const LatencyMetricTimestamp&); int64_t latency_metric_timestamp; }; @@ -53,15 +54,19 @@ class LatencyMetric { private: void report(); const char* message; - int64_t ignore, count, total, skipped, skip; + int64_t count, total, skipped, skip; }; }} // namespace qpid::sys #define QPID_LATENCY_INIT(x) ::qpid::sys::LatencyMetricTimestamp::initialize(x) +#define QPID_LATENCY_CLEAR(x) ::qpid::sys::LatencyMetricTimestamp::clear(x) #define QPID_LATENCY_RECORD(msg, x) do { \ static ::qpid::sys::LatencyMetric metric__(msg); metric__.record(x); \ } while (false) +#define QPID_LATENCY_RECORD_SKIP(msg, x, skip) do { \ + static ::qpid::sys::LatencyMetric metric__(msg, skip); metric__.record(x); \ + } while (false) #else /* defined QPID_LATENCY_METRIC */ @@ -71,7 +76,9 @@ class LatencyMetricTimestamp {}; }} #define QPID_LATENCY_INIT(x) (void)x +#define QPID_LATENCY_CLEAR(x) (void)x #define QPID_LATENCY_RECORD(msg, x) (void)x +#define QPID_LATENCY_RECORD_SKIP(msg, x, skip) (void)x #endif /* defined QPID_LATENCY_METRIC */ -- cgit v1.2.1