Merge pull request #2665 from psychon/util-errors

Use xcb-errors library if it is available
This commit is contained in:
Daniel Hahler 2019-03-03 11:11:26 +01:00 committed by GitHub
commit d21fd74efc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 68 additions and 5 deletions

View File

@ -64,13 +64,15 @@ jobs:
- *BASE_PACKAGES - *BASE_PACKAGES
- liblua5.3-dev - liblua5.3-dev
- lua5.3 - lua5.3
- env: LUA=5.1 LUANAME=lua5.1 BUILD_IN_DIR=/tmp/awesome-build - env: LUA=5.1 LUANAME=lua5.1 BUILD_IN_DIR=/tmp/awesome-build WITH_XCB_ERRORS=yes
addons: addons:
apt: apt:
packages: packages:
- *BASE_PACKAGES - *BASE_PACKAGES
- liblua5.1-dev - liblua5.1-dev
- lua5.1 - lua5.1
# For xcb-errors
- xcb-proto
- env: LUA=5.1 LUANAME=luajit-2.0 LUALIBRARY=/usr/lib/x86_64-linux-gnu/libluajit-5.1.so LUAROCKS_ARGS=--lua-suffix=jit-2.0.4 - env: LUA=5.1 LUANAME=luajit-2.0 LUALIBRARY=/usr/lib/x86_64-linux-gnu/libluajit-5.1.so LUAROCKS_ARGS=--lua-suffix=jit-2.0.4
addons: addons:
apt: apt:
@ -110,6 +112,16 @@ install:
./autogen.sh --prefix=/usr ./autogen.sh --prefix=/usr
make && sudo make install) make && sudo make install)
# Install xcb-errors if needed
- |
set -e
if [[ "$WITH_XCB_ERRORS" == "yes" ]]; then
git clone --depth 1 --recursive https://gitlab.freedesktop.org/xorg/lib/libxcb-errors.git /tmp/xcb-errors
(cd /tmp/xcb-errors
./autogen.sh --prefix=/usr
make && sudo make install)
fi
- | - |
# Install Lua (per env). # Install Lua (per env).
if [[ "$LUANAME" == "luajit-2.0" ]]; then if [[ "$LUANAME" == "luajit-2.0" ]]; then

View File

@ -145,6 +145,9 @@ awesome_atexit(bool restart)
/* Disconnect *after* closing lua */ /* Disconnect *after* closing lua */
xcb_cursor_context_free(globalconf.cursor_ctx); xcb_cursor_context_free(globalconf.cursor_ctx);
#ifdef WITH_XCB_ERRORS
xcb_errors_context_free(globalconf.errors_ctx);
#endif
xcb_disconnect(globalconf.connection); xcb_disconnect(globalconf.connection);
close(sigchld_pipe[0]); close(sigchld_pipe[0]);
@ -751,6 +754,11 @@ main(int argc, char **argv)
globalconf.visual->visual_id); globalconf.visual->visual_id);
} }
#ifdef WITH_XCB_ERRORS
if (xcb_errors_context_new(globalconf.connection, &globalconf.errors_ctx) < 0)
fatal("Failed to initialize xcb-errors");
#endif
/* Get a recent timestamp */ /* Get a recent timestamp */
acquire_timestamp(); acquire_timestamp();

View File

@ -13,6 +13,7 @@ autoOption(GENERATE_MANPAGES "generate manpages")
option(COMPRESS_MANPAGES "compress manpages" ON) option(COMPRESS_MANPAGES "compress manpages" ON)
option(GENERATE_DOC "generate API documentation" ON) option(GENERATE_DOC "generate API documentation" ON)
option(DO_COVERAGE "build with coverage" OFF) option(DO_COVERAGE "build with coverage" OFF)
autoOption(WITH_XCB_ERRORS "build with xcb-errors")
if (GENERATE_DOC AND DO_COVERAGE) if (GENERATE_DOC AND DO_COVERAGE)
message(STATUS "Not generating API documentation with DO_COVERAGE") message(STATUS "Not generating API documentation with DO_COVERAGE")
set(GENERATE_DOC OFF) set(GENERATE_DOC OFF)
@ -213,6 +214,16 @@ if(WITH_DBUS)
autoDisable(WITH_DBUS "DBus not found.") autoDisable(WITH_DBUS "DBus not found.")
endif() endif()
endif() endif()
if(WITH_XCB_ERRORS)
pkg_check_modules(XCB_ERRORS xcb-errors)
if(XCB_ERRORS_FOUND)
set(AWESOME_OPTIONAL_LDFLAGS ${AWESOME_OPTIONAL_LDFLAGS} ${XCB_ERRORS_LDFLAGS})
set(AWESOME_OPTIONAL_INCLUDE_DIRS ${AWESOME_OPTIONAL_INCLUDE_DIRS} ${XCB_ERRORS_INCLUDE_DIRS})
else()
autoDisable(WITH_XCB_ERRORS "xcb-errors not found.")
endif()
endif()
# }}} # }}}
# {{{ Install path and configuration variables # {{{ Install path and configuration variables

View File

@ -54,6 +54,11 @@ eprint_version(void)
#else #else
const char *has_dbus = ""; const char *has_dbus = "";
#endif #endif
#ifdef WITH_XCB_ERRORS
const char *has_xcb_errors = "";
#else
const char *has_xcb_errors = "";
#endif
#ifdef HAS_EXECINFO #ifdef HAS_EXECINFO
const char *has_execinfo = ""; const char *has_execinfo = "";
#else #else
@ -63,12 +68,13 @@ eprint_version(void)
printf("awesome %s (%s)\n" printf("awesome %s (%s)\n"
" • Compiled against %s (running with %s)\n" " • Compiled against %s (running with %s)\n"
" • D-Bus support: %s\n" " • D-Bus support: %s\n"
" • xcb-errors support: %s\n"
" • execinfo support: %s\n" " • execinfo support: %s\n"
" • xcb-randr version: %d.%d\n" " • xcb-randr version: %d.%d\n"
" • LGI version: %s\n", " • LGI version: %s\n",
AWESOME_VERSION, AWESOME_RELEASE, AWESOME_VERSION, AWESOME_RELEASE,
LUA_RELEASE, lua_tostring(L, -2), LUA_RELEASE, lua_tostring(L, -2),
has_dbus, has_execinfo, has_dbus, has_xcb_errors, has_execinfo,
XCB_RANDR_MAJOR_VERSION, XCB_RANDR_MINOR_VERSION, XCB_RANDR_MAJOR_VERSION, XCB_RANDR_MINOR_VERSION,
lua_tostring(L, -1)); lua_tostring(L, -1));
lua_close(L); lua_close(L);

View File

@ -8,6 +8,7 @@
#define AWESOME_DEFAULT_CONF "@AWESOME_SYSCONFDIR@/rc.lua" #define AWESOME_DEFAULT_CONF "@AWESOME_SYSCONFDIR@/rc.lua"
#cmakedefine WITH_DBUS #cmakedefine WITH_DBUS
#cmakedefine WITH_XCB_ERRORS
#cmakedefine HAS_EXECINFO #cmakedefine HAS_EXECINFO
#endif //_CONFIG_H_ #endif //_CONFIG_H_

View File

@ -102,6 +102,8 @@ Additionally, the following optional dependencies exist:
generate slightly better backtraces on crashes generate slightly better backtraces on crashes
- `Xephyr` or `Xvfb` for running integration tests - `Xephyr` or `Xvfb` for running integration tests
- [GTK+ >= 3.10](https://www.gtk.org/) for `./themes/gtk/` - [GTK+ >= 3.10](https://www.gtk.org/) for `./themes/gtk/`
- [xcb-errors](https://gitlab.freedesktop.org/xorg/lib/libxcb-errors) for
pretty-printing of X11 errors
## Running Awesome ## Running Awesome

20
event.c
View File

@ -1036,10 +1036,24 @@ xerror(xcb_generic_error_t *e)
&& e->major_code == XCB_CONFIGURE_WINDOW)) && e->major_code == XCB_CONFIGURE_WINDOW))
return; return;
warn("X error: request=%s (major %d, minor %d), error=%s (%d)", #ifdef WITH_XCB_ERRORS
xcb_event_get_request_label(e->major_code), const char *major = xcb_errors_get_name_for_major_code(
globalconf.errors_ctx, e->major_code);
const char *minor = xcb_errors_get_name_for_minor_code(
globalconf.errors_ctx, e->major_code, e->minor_code);
const char *extension = NULL;
const char *error = xcb_errors_get_name_for_error(
globalconf.errors_ctx, e->error_code, &extension);
#else
const char *major = xcb_event_get_request_label(e->major_code);
const char *minor = NULL;
const char *extension = NULL;
const char *error = xcb_event_get_error_label(e->error_code);
#endif
warn("X error: request=%s%s%s (major %d, minor %d), error=%s%s%s (%d)",
major, minor == NULL ? "" : "-", NONULL(minor),
e->major_code, e->minor_code, e->major_code, e->minor_code,
xcb_event_get_error_label(e->error_code), NONULL(extension), extension == NULL ? "" : "-", error,
e->error_code); e->error_code);
return; return;

View File

@ -33,6 +33,11 @@
#include <xcb/xcb_xrm.h> #include <xcb/xcb_xrm.h>
#include <X11/Xresource.h> #include <X11/Xresource.h>
#include "config.h"
#ifdef WITH_XCB_ERRORS
#include <xcb/xcb_errors.h>
#endif
#include "objects/key.h" #include "objects/key.h"
#include "common/xembed.h" #include "common/xembed.h"
#include "common/buffer.h" #include "common/buffer.h"
@ -82,6 +87,10 @@ typedef struct
int default_screen; int default_screen;
/** xcb-cursor context */ /** xcb-cursor context */
xcb_cursor_context_t *cursor_ctx; xcb_cursor_context_t *cursor_ctx;
#ifdef WITH_XCB_ERRORS
/** xcb-errors context */
xcb_errors_context_t *errors_ctx;
#endif
/** Keys symbol table */ /** Keys symbol table */
xcb_key_symbols_t *keysyms; xcb_key_symbols_t *keysyms;
/** Logical screens */ /** Logical screens */