wayland-util: calls wl_log_handler only when dlog is not available or when there...
authorSung-Jin Park <sj76.park@samsung.com>
Tue, 28 Jul 2020 09:26:52 +0000 (18:26 +0900)
committerJunkyeong Kim <jk0430.kim@samsung.com>
Thu, 16 Feb 2023 10:12:07 +0000 (19:12 +0900)
Change-Id: If3ebe372467d528f96554790de9defb657b710f8
Signed-off-by: Sung-Jin Park <sj76.park@samsung.com>
src/wayland-util.c

index 7df4f81..bf0148b 100644 (file)
@@ -501,19 +501,24 @@ void
 wl_log(const char *fmt, ...)
 {
        va_list argp;
+       static int has_dlog = 0;
 
        wl_abort_errno = errno;
 
 #ifdef HAVE_DLOG
-       dlog_print(DLOG_ERROR, WLLOG_TAG, "[wl_abort] abort_errno=%d (%s)", wl_abort_errno, strerror(wl_abort_errno));
+       has_dlog = 1;
        va_start(argp, fmt);
        dlog_vprint(DLOG_ERROR, WLLOG_TAG, fmt, argp);
        va_end(argp);
 #endif
 
-       va_start(argp, fmt);
-       wl_log_handler(fmt, argp);
-       va_end(argp);
+       /* Disable printing log to stderr when it is being printed via dlog.
+        * If wl_log_handler has been overriden, it must be called to handle logs properly. */
+       if (!has_dlog || (wl_log_handler != wl_log_stderr_handler)) {
+               va_start(argp, fmt);
+               wl_log_handler(fmt, argp);
+               va_end(argp);
+       }
 }
 
 void