X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Futil.hpp;h=5d602edcc335823c6d6926c4d37cb659a9249e50;hb=9a5202f6d3642ea08e1b72340dd4eebad835e082;hp=ab9019b0e5ca0e8eddc10471f3b3bffdc69f4945;hpb=d79d0c83452212355d212e8fcd4ad5c27c1906fc;p=staging%2Fwindowmanager.git diff --git a/src/util.hpp b/src/util.hpp index ab9019b..5d602ed 100644 --- a/src/util.hpp +++ b/src/util.hpp @@ -18,14 +18,18 @@ #define WM_UTIL_HPP #include -#include - +#include #include +#include + extern "C" { #include }; +#define CONCAT_(X, Y) X##Y +#define CONCAT(X, Y) CONCAT_(X, Y) + #ifdef __GNUC__ #define ATTR_FORMAT(stringindex, firsttocheck) \ __attribute__((format(printf, stringindex, firsttocheck))) @@ -49,6 +53,23 @@ extern "C" { #define logdebug(...) #endif +#ifndef SCOPE_TRACING +#define ST() +#define STN(N) +#else +#define ST() \ + ScopeTrace __attribute__((unused)) CONCAT(trace_scope_, __LINE__)(__func__) +#define STN(N) \ + ScopeTrace __attribute__((unused)) CONCAT(named_trace_scope_, __LINE__)(#N) + +struct ScopeTrace { + thread_local static int indent; + char const *f{}; + explicit ScopeTrace(char const *func); + ~ScopeTrace(); +}; +#endif + // _ _ _ __ _ // ___| |_ _ __ _ _ ___| |_ _ _ _ __ (_) __ _ _ _ ___ / _| __| | // / __| __| '__| | | |/ __| __| | | | | '_ \| |/ _` | | | |/ _ \ | |_ / _` |