aboutsummaryrefslogtreecommitdiff
path: root/thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp')
-rw-r--r--thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp54
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;
+}