diff options
author | Drew DeVault <sir@cmpwn.com> | 2015-10-25 08:58:34 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2015-10-25 08:58:34 -0400 |
commit | eb847a1b1ce122f6621de0fb76e381bf0d10b317 (patch) | |
tree | a72bb20cd5dcdf6f328e6f5cfbd9da870fd82027 /sway/log.c | |
parent | 010368150bf814a05e35d8fe34cf20c4739c5781 (diff) | |
parent | 83ca7d3a5ccc3943de80cd07bd52e7005b13ab75 (diff) | |
download | sway-eb847a1b1ce122f6621de0fb76e381bf0d10b317.tar.xz |
Merge pull request #204 from sce/misc_stuff
Misc stuff
Diffstat (limited to 'sway/log.c')
-rw-r--r-- | sway/log.c | 27 |
1 files changed, 27 insertions, 0 deletions
@@ -187,4 +187,31 @@ void layout_log(const swayc_t *c, int depth) { } } } + +const char *swayc_type_string(enum swayc_types type) { + return type == C_ROOT ? "ROOT" : + type == C_OUTPUT ? "OUTPUT" : + type == C_WORKSPACE ? "WORKSPACE" : + type == C_CONTAINER ? "CONTAINER" : + type == C_VIEW ? "VIEW" : + "UNKNOWN"; +} + +// Like sway_log, but also appends some info about given container to log output. +void swayc_log(log_importance_t verbosity, swayc_t *cont, const char* format, ...) { + sway_assert(cont, "swayc_log: no container ..."); + va_list args; + va_start(args, format); + char *txt = malloc(128); + vsprintf(txt, format, args); + va_end(args); + + char *debug_txt = malloc(32); + snprintf(debug_txt, 32, "%s '%s'", swayc_type_string(cont->type), cont->name); + + sway_log(verbosity, "%s (%s)", txt, debug_txt); + free(txt); + free(debug_txt); +} + /* XXX:DEBUG:XXX */ |