diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 12:15:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 12:15:43 +0000 |
commit | f5f56e1a1c4d9e9496fcb9d81131066a964ccd23 (patch) | |
tree | 49e44c6f87febed37efb953ab5485aa49f6481a7 /src/lib/util/stopwatch.cc | |
parent | Initial commit. (diff) | |
download | isc-kea-upstream.tar.xz isc-kea-upstream.zip |
Adding upstream version 2.4.1.upstream/2.4.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/lib/util/stopwatch.cc')
-rw-r--r-- | src/lib/util/stopwatch.cc | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/src/lib/util/stopwatch.cc b/src/lib/util/stopwatch.cc new file mode 100644 index 0000000..f75c6cd --- /dev/null +++ b/src/lib/util/stopwatch.cc @@ -0,0 +1,85 @@ +// Copyright (C) 2015 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#include <config.h> + +#include <util/stopwatch.h> +#include <util/stopwatch_impl.h> + +namespace isc { +namespace util { + +using namespace boost::posix_time; + +Stopwatch::Stopwatch(const bool autostart) + : impl_(new StopwatchImpl()) { + // If the autostart has been specified, invoke start. + if (autostart) { + start(); + } +} + +Stopwatch::~Stopwatch() { + delete impl_; +} + +void +Stopwatch::start() { + impl_->start(); +} + +void +Stopwatch::stop() { + impl_->stop(); +} + +void +Stopwatch::reset() { + impl_->reset(); +} + +boost::posix_time::time_duration +Stopwatch::getLastDuration() const { + return (impl_->getLastDuration()); +} + +boost::posix_time::time_duration +Stopwatch::getTotalDuration() const { + return (impl_->getTotalDuration()); +} + +long +Stopwatch::getLastMilliseconds() const { + return (getLastDuration().total_milliseconds()); +} + +long +Stopwatch::getTotalMilliseconds() const { + return (getTotalDuration().total_milliseconds()); +} + +long +Stopwatch::getLastMicroseconds() const { + return (getLastDuration().total_microseconds()); +} + +long +Stopwatch::getTotalMicroseconds() const { + return (getTotalDuration().total_microseconds()); +} + +std::string +Stopwatch::logFormatLastDuration() const { + return (StopwatchImpl::logFormat(getLastDuration())); +} + +std::string +Stopwatch::logFormatTotalDuration() const { + return (StopwatchImpl::logFormat(getTotalDuration())); +} + +} // end of isc::util +} // end of isc |