X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Futil.hpp;h=b3f43de882f1af86ad7c8af7e0003717c5b91c34;hb=9fcedd79dd25767658b653ed04a77cf65316b0a5;hp=0703809f870ff0a6cac894b5b545e27e34c9be86;hpb=add2152e7561ea456068dd73ebbdc480d13e1015;p=staging%2Fwindowmanager.git diff --git a/src/util.hpp b/src/util.hpp index 0703809..b3f43de 100644 --- a/src/util.hpp +++ b/src/util.hpp @@ -18,13 +18,19 @@ #define WM_UTIL_HPP #include -#include - +#include #include +#include + +#ifndef DO_NOT_USE_AFB extern "C" { #include }; +#endif + +#define CONCAT_(X, Y) X##Y +#define CONCAT(X, Y) CONCAT_(X, Y) #ifdef __GNUC__ #define ATTR_FORMAT(stringindex, firsttocheck) \ @@ -35,6 +41,7 @@ extern "C" { #define ATTR_NORETURN #endif +#ifdef AFB_BINDING_VERSION #define lognotice(...) AFB_NOTICE(__VA_ARGS__) #define logerror(...) AFB_ERROR(__VA_ARGS__) #define fatal(...) \ @@ -42,22 +49,40 @@ extern "C" { AFB_ERROR(__VA_ARGS__); \ abort(); \ } while (0) +#else +#define lognotice(...) +#define logerror(...) +#define fatal(...) \ + do { \ + abort(); \ + } while (0) +#endif #ifdef DEBUG_OUTPUT +#ifdef AFB_BINDING_VERSION #define logdebug(...) AFB_DEBUG(__VA_ARGS__) #else #define logdebug(...) #endif +#else +#define logdebug(...) +#endif -#ifndef NDEBUG -#define DB(expr) \ - do { \ - std::ostringstream o; \ - o << __FILE__ << ":" << __LINE__ << ":" << __func__ << ": " << expr; \ - logdebug("%s", o.str().c_str()); \ - } while (0) +#ifndef SCOPE_TRACING +#define ST() +#define STN(N) #else -#define DB(expr) +#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 // _ _ _ __ _