X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;ds=sidebyside;f=src%2Futil.hpp;h=ff173c812af37b2bbb4092afe4a5b840468903a9;hb=2f864ac5289e8426f1d0c91c264a6a274047245b;hp=73ddb049c00cf0b4da1684952fc9ab24eaa2fe9a;hpb=daf3f38d2d89b0073bdbee2a531e00dc00e172c1;p=staging%2Fwindowmanager.git diff --git a/src/util.hpp b/src/util.hpp index 73ddb04..ff173c8 100644 --- a/src/util.hpp +++ b/src/util.hpp @@ -18,10 +18,11 @@ #define WM_UTIL_HPP #include -#include - +#include #include +#include + extern "C" { #include }; @@ -49,15 +50,26 @@ extern "C" { #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) +#ifdef NDEBUG +#define ST() +#define STN(N) #else -#define DB(expr) +#define CONCAT_(X, Y) X##Y +#define CONCAT(X, Y) CONCAT_(X, Y) + +#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) : f(func) { + fprintf(stderr, "%lu %*s%s -->\n", pthread_self(), 2 * indent++, "", this->f); + } + ~ScopeTrace() { fprintf(stderr, "%lu %*s%s <--\n", pthread_self(), 2 * --indent, "", this->f); } +}; #endif // _ _ _ __ _ @@ -81,19 +93,4 @@ struct unique_fd { } }; -// _ _ ____ _ _ -// ___| |_ _ __ _ _ ___| |_ | _ \ ___ | | | ___ _ __ -// / __| __| '__| | | |/ __| __| | |_) / _ \| | |/ _ \ '__| -// \__ \ |_| | | |_| | (__| |_ | __/ (_) | | | __/ | -// |___/\__|_| \__,_|\___|\__| |_| \___/|_|_|\___|_| -// -struct Poller { - std::vector> handlers; - std::vector pfds; - - Poller() = default; - void add_fd(int fd, std::function handler); - int check_events(); -}; - #endif // !WM_UTIL_HPP