Files
scylladb/utils/latency.hh
Avi Kivity fcb8d040e8 treewide: use Software Package Data Exchange (SPDX) license identifiers
Instead of lengthy blurbs, switch to single-line, machine-readable
standardized (https://spdx.dev) license identifiers. The Linux kernel
switched long ago, so there is strong precedent.

Three cases are handled: AGPL-only, Apache-only, and dual licensed.
For the latter case, I chose (AGPL-3.0-or-later and Apache-2.0),
reasoning that our changes are extensive enough to apply our license.

The changes we applied mechanically with a script, except to
licenses/README.md.

Closes #9937
2022-01-18 12:15:18 +01:00

61 lines
1.1 KiB
C++

/*
* Copyright (C) 2015-present ScyllaDB
*/
/*
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
#pragma once
#include <chrono>
/**
* A helper class to keep track of latencies
*/
namespace utils {
class latency_counter {
public:
using clock = std::chrono::steady_clock;
using time_point = clock::time_point;
using duration = clock::duration;
private:
time_point _start;
time_point _stop;
public:
void start() {
_start = now();
}
bool is_start() const {
// if start is not set it is still zero
return _start.time_since_epoch().count();
}
latency_counter& stop() {
_stop = now();
return *this;
}
bool is_stopped() const {
// if stop was not set, it is still zero
return _stop.time_since_epoch().count();
}
duration latency() const {
return _stop - _start;
}
latency_counter& check_and_stop() {
if (!is_stopped()) {
return stop();
}
return *this;
}
static time_point now() {
return clock::now();
}
};
}