diff options
Diffstat (limited to 'thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp')
| -rw-r--r-- | thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp b/thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp new file mode 100644 index 000000000..74b3fb04e --- /dev/null +++ b/thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp @@ -0,0 +1,54 @@ +// Copyright 2011-2022, Molecular Matters GmbH <[email protected]> +// See LICENSE.txt for licensing details (2-clause BSD License: https://opensource.org/licenses/BSD-2-Clause) + +#include "Examples_PCH.h" +#include "ExampleTimedScope.h" + +namespace +{ + static unsigned int g_indent = 0u; + + static void PrintIndent(void) + { + printf("%.*s", g_indent * 2u, "| | | | | | | | "); + } +} + + +TimedScope::TimedScope(const char* message) + : m_begin(std::chrono::high_resolution_clock::now()) +{ + PrintIndent(); + ++g_indent; + + printf("%s\n", message); +} + + +void TimedScope::Done(void) const +{ + --g_indent; + PrintIndent(); + + const double milliSeconds = ReadMilliseconds(); + printf("---> done in %.3fms\n", milliSeconds); +} + + +void TimedScope::Done(size_t count) const +{ + --g_indent; + PrintIndent(); + + const double milliSeconds = ReadMilliseconds(); + printf("---> done in %.3fms (%zu elements)\n", milliSeconds, count); +} + + +double TimedScope::ReadMilliseconds(void) const +{ + const std::chrono::high_resolution_clock::time_point now = std::chrono::high_resolution_clock::now(); + const std::chrono::duration<double> seconds = now - m_begin; + + return seconds.count() * 1000.0; +} |