diff options
| author | Stefan Boberg <[email protected]> | 2026-04-23 18:16:57 +0200 |
|---|---|---|
| committer | Stefan Boberg <[email protected]> | 2026-04-23 18:16:57 +0200 |
| commit | 0232b991cd7d8e3a2114ea30e4591dd3e7b65c36 (patch) | |
| tree | 94730e7594fd09ae1fa820391ce311f6daf13905 /thirdparty/raw_pdb/src/Examples/ExampleTimedScope.cpp | |
| parent | Fix forward declaration order for s_GotSigWinch and SigWinchHandler (diff) | |
| parent | trace: declare Region event name fields as AnsiString (#1012) (diff) | |
| download | archived-zen-sb/zen-help.tar.xz archived-zen-sb/zen-help.zip | |
Merge branch 'main' into sb/zen-helpsb/zen-help
- Combine HelpCommand (this branch) with HistoryCommand (main) in zen CLI dispatcher
- Keep filter-aware TuiPickOne rewrite; adopt main's ASCII arrow glyphs in doc comment
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; +} |