Merge pull request #2665 from psychon/util-errors
Use xcb-errors library if it is available
This commit is contained in:
commit
d21fd74efc
14
.travis.yml
14
.travis.yml
|
@ -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
|
||||||
|
|
|
@ -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();
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
1
config.h
1
config.h
|
@ -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_
|
||||||
|
|
|
@ -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
20
event.c
|
@ -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;
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
Loading…
Reference in New Issue