diff options
author | Stefan Radomski <github@mintwerk.de> | 2017-07-05 11:35:04 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-07-05 11:35:04 (GMT) |
commit | cb2f533085542a753fc45d17fdb09396c46fbadc (patch) | |
tree | 66d378d1df7cb82834e944a1f37865809abf75ae /src/uscxml/debug/Benchmark.cpp | |
parent | 3f10e11d6ad2b97fee4aee6e09bc959ba9b8e0e5 (diff) | |
parent | a0f96c5dd050c524223ac644ba8798bc7cc80bfd (diff) | |
download | uscxml-cb2f533085542a753fc45d17fdb09396c46fbadc.zip uscxml-cb2f533085542a753fc45d17fdb09396c46fbadc.tar.gz uscxml-cb2f533085542a753fc45d17fdb09396c46fbadc.tar.bz2 |
Merge pull request #155 from tklab-tud/sradomski
More performant monitors with slight API break
Diffstat (limited to 'src/uscxml/debug/Benchmark.cpp')
-rw-r--r-- | src/uscxml/debug/Benchmark.cpp | 42 |
1 files changed, 21 insertions, 21 deletions
diff --git a/src/uscxml/debug/Benchmark.cpp b/src/uscxml/debug/Benchmark.cpp index 0d2d789..b529bb4 100644 --- a/src/uscxml/debug/Benchmark.cpp +++ b/src/uscxml/debug/Benchmark.cpp @@ -23,33 +23,33 @@ namespace uscxml { std::mutex Benchmark::benchMutex; std::map<std::string, size_t> Benchmark::benchmarks; - + Benchmark::Benchmark(const std::string& domain) : domain(domain), started(std::chrono::system_clock::now()) { } Benchmark::~Benchmark() { - std::lock_guard<std::mutex> lock(benchMutex); - benchmarks[domain] += std::chrono::duration_cast<std::chrono::microseconds>(std::chrono::system_clock::now() - started).count(); + std::lock_guard<std::mutex> lock(benchMutex); + benchmarks[domain] += std::chrono::duration_cast<std::chrono::microseconds>(std::chrono::system_clock::now() - started).count(); } - + std::ostream& Benchmark::report(std::ostream& stream) { - std::lock_guard<std::mutex> lock(benchMutex); - - size_t longestDomain = 0; - for (auto benchmark : benchmarks) { - longestDomain = (benchmark.first.size() > longestDomain ? benchmark.first.size() : longestDomain); - } - longestDomain += 8; - - for (auto benchmark : benchmarks) { - std::string padding; - for (int i = benchmark.first.size(); i < (longestDomain - log10(benchmark.second)); i++) { - padding += " "; - } - - stream << benchmark.first << ":" << padding << (double)benchmark.second / 1000.0 << "ms" << std::endl; - } - return stream; + std::lock_guard<std::mutex> lock(benchMutex); + + size_t longestDomain = 0; + for (auto benchmark : benchmarks) { + longestDomain = (benchmark.first.size() > longestDomain ? benchmark.first.size() : longestDomain); + } + longestDomain += 8; + + for (auto benchmark : benchmarks) { + std::string padding; + for (int i = benchmark.first.size(); i < (longestDomain - log10(benchmark.second)); i++) { + padding += " "; + } + + stream << benchmark.first << ":" << padding << (double)benchmark.second / 1000.0 << "ms" << std::endl; + } + return stream; } } |