14namespace Stroika::Foundation::Debug {
17 struct ModuleInit_ final {
18 ModuleInit_ () noexcept;
21 const inline ModuleInit_ _MI_;
24 class Private_::Emitter final {
27 Emitter (
const Emitter&) =
delete;
30 static Emitter& Get () noexcept;
36 [[deprecated ("Since Stroika v3.0d6 - use _f format strings")]]
void EmitTraceMessage (const
char* format, ...) noexcept;
37 [[deprecated ("Since Stroika v3.0d6 - use _f format strings")]]
void EmitTraceMessage (const
wchar_t* format, ...) noexcept;
39 template <typename CHAR_T, Common::StdCompat::formattable<
wchar_t>... Args>
40 nonvirtual
void EmitTraceMessage (Characters::FormatString<CHAR_T> fmt, Args&&... args) noexcept
43 EmitTraceMessage_ (fmt.get (), Common::StdCompat::make_wformat_args (args...));
50 nonvirtual TraceLastBufferedWriteTokenType EmitTraceMessage_ (
size_t bufferLastNChars, wstring_view format,
51 Common::StdCompat::wformat_args&& args)
noexcept;
52 nonvirtual
void EmitTraceMessage_ (wstring_view format, Common::StdCompat::wformat_args&& args)
noexcept;
53 nonvirtual
void EmitTraceMessage_ (string_view format, Common::StdCompat::format_args&& args)
noexcept;
54 nonvirtual
void EmitTraceMessage_ (
const wstring& raw)
noexcept;
59 nonvirtual
bool UnputBufferedCharactersForMatchingToken (TraceLastBufferedWriteTokenType token);
61 template <
typename CHARTYPE>
62 nonvirtual
void EmitUnadornedText (
const CHARTYPE* p);
66 template <
typename CHARTYPE>
67 nonvirtual TraceLastBufferedWriteTokenType DoEmitMessage_ (
size_t bufferLastNChars,
const CHARTYPE* p,
const CHARTYPE* e);
70 size_t fLastNCharBufCharCount_{0};
71 char fLastNCharBuf_CHAR_[10];
72 wchar_t fLastNCharBuf_WCHAR_[10];
73 bool fLastNCharBuf_WCHARFlag_{
false};
74 TraceLastBufferedWriteTokenType fLastNCharBuf_Token_{0};
75 Time::DisplayedRealtimeClock::time_point fLastNCharBuf_WriteTickcount_{};
77 nonvirtual
void BufferNChars_ (
size_t nChars,
const char* p);
78 nonvirtual
void BufferNChars_ (
size_t nChars,
const wchar_t* p);
81 nonvirtual
void FlushBufferedCharacters_ ();
84 nonvirtual
void DoEmit_ (
const char* p)
noexcept;
85 nonvirtual
void DoEmit_ (
const wchar_t* p)
noexcept;
86 nonvirtual
void DoEmit_ (
const char* p,
const char* e)
noexcept;
87 nonvirtual
void DoEmit_ (
const wchar_t* p,
const wchar_t* e)
noexcept;
90 friend class Debug::TraceContextBumper;
100#if qStroika_Foundation_Debug_DefaultTracingOn
104 template <
typename CHAR_T>
106 requires (same_as<CHAR_T, char> or same_as<CHAR_T, wchar_t>)
107#
if qStroika_Foundation_Debug_DefaultTracingOn
112 template <
typename CHAR_T,
typename FCHAR_T,
typename... ARGS>
115 requires ((same_as<CHAR_T, char> or same_as<CHAR_T, wchar_t>) and (same_as<FCHAR_T, char> or same_as<FCHAR_T, wchar_t>))
116#
if qStroika_Foundation_Debug_DefaultTracingOn
117 : TraceContextBumper{cvt2WChartArrayTrunc_ (contextName), ProcessFmtString_ (fmt, forward<ARGS> (args)...)}
121#if !qStroika_Foundation_Debug_DefaultTracingOn
126#if qStroika_Foundation_Debug_DefaultTracingOn
127 template <
typename CHAR_T,
typename... ARGS>
128 auto TraceContextBumper::ProcessFmtString_ (Characters::FormatString<CHAR_T> fmt, ARGS&&... args)
noexcept -> CHAR_ARRAY_T
129 requires (same_as<CHAR_T, char> or same_as<CHAR_T, wchar_t>)
132 wstring r = Common::StdCompat::vformat (qStroika_Foundation_Characters_FMT_PREFIX_::wstring_view{fmt.get ()},
133 Common::StdCompat::make_wformat_args (args...));
134 size_t len = min<size_t> (r.size (), kMaxContextNameLen_);
137 char_traits<wchar_t>::copy (result.data (), r.data (), len);
149 template <
typename CHAR_T>
150 auto TraceContextBumper::cvt2WChartArrayTrunc_ (span<const CHAR_T> contextName) -> CHAR_ARRAY_T
153 array<wchar_t, kMaxContextNameLen_ + 1> r;
154 auto ci = contextName.begin ();
155 for (; ci != contextName.end (); ++ci) {
156 size_t i = ci - contextName.begin ();
157 if (i < kMaxContextNameLen_) {
164 Assert (ci - contextName.begin () <= kMaxContextNameLen_);
165 r[ci - contextName.begin ()] =
'\0';
168 template <
typename CHAR_T>
169 auto TraceContextBumper::cvt2WChartArrayTrunc_ (
const CHAR_T* contextName) -> CHAR_ARRAY_T
171 return cvt2WChartArrayTrunc_ (span{contextName, char_traits<CHAR_T>::length (contextName)});
180 inline TraceContextSuppressor::TraceContextSuppressor () noexcept
184 inline TraceContextSuppressor::~TraceContextSuppressor ()
188 inline bool TraceContextSuppressor::GetSuppressTraceInThisThread ()
190 return tSuppressCnt_ > 0;
#define CompileTimeFlagChecker_HEADER(NS_PREFIX, NAME, VALUE)
CompileTimeFlagChecker_HEADER () will generate a LINK ERROR if you ever compile a header with one val...
#define qStroika_Foundation_Debug_TraceToFile
TraceContextBumper() noexcept