Stop using most of libxcb-event
Upstream removed most of the code from libxcb-event and there is no event-related stuff left in this library. We now no longer use any of the parts that were removed. Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
parent
0262e39609
commit
58bb601658
67
awesome.c
67
awesome.c
|
@ -208,14 +208,14 @@ a_xcb_check_cb(EV_P_ ev_check *w, int revents)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
xcb_event_handle(&globalconf.evenths, event);
|
event_handle(event);
|
||||||
p_delete(&event);
|
p_delete(&event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(mouse)
|
if(mouse)
|
||||||
{
|
{
|
||||||
xcb_event_handle(&globalconf.evenths, mouse);
|
event_handle(mouse);
|
||||||
p_delete(&mouse);
|
p_delete(&mouse);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -226,20 +226,6 @@ a_xcb_io_cb(EV_P_ ev_io *w, int revents)
|
||||||
/* empty */
|
/* empty */
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Startup Error handler to check if another window manager
|
|
||||||
* is already running.
|
|
||||||
* \param data Additional optional parameters data.
|
|
||||||
* \param c X connection.
|
|
||||||
* \param error Error event.
|
|
||||||
*/
|
|
||||||
static int __attribute__ ((noreturn))
|
|
||||||
xerrorstart(void * data __attribute__ ((unused)),
|
|
||||||
xcb_connection_t * c __attribute__ ((unused)),
|
|
||||||
xcb_generic_error_t * error __attribute__ ((unused)))
|
|
||||||
{
|
|
||||||
fatal("another window manager is already running");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
signal_fatal(int signum)
|
signal_fatal(int signum)
|
||||||
{
|
{
|
||||||
|
@ -275,37 +261,6 @@ restart_on_signal(EV_P_ ev_signal *w, int revents)
|
||||||
awesome_restart();
|
awesome_restart();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** \brief awesome xerror function.
|
|
||||||
* There's no way to check accesses to destroyed windows, thus those cases are
|
|
||||||
* ignored (especially on UnmapNotify's). Other types of errors call Xlibs
|
|
||||||
* default error handler, which may call exit.
|
|
||||||
* \param data Currently unused.
|
|
||||||
* \param c The connection to the X server.
|
|
||||||
* \param e The error event.
|
|
||||||
* \return 0 if no error, or xerror's xlib return status.
|
|
||||||
*/
|
|
||||||
static int
|
|
||||||
xerror(void *data __attribute__ ((unused)),
|
|
||||||
xcb_connection_t *c __attribute__ ((unused)),
|
|
||||||
xcb_generic_error_t *e)
|
|
||||||
{
|
|
||||||
/* ignore this */
|
|
||||||
if(e->error_code == XCB_EVENT_ERROR_BAD_WINDOW
|
|
||||||
|| (e->error_code == XCB_EVENT_ERROR_BAD_MATCH
|
|
||||||
&& e->major_code == XCB_SET_INPUT_FOCUS)
|
|
||||||
|| (e->error_code == XCB_EVENT_ERROR_BAD_VALUE
|
|
||||||
&& e->major_code == XCB_KILL_CLIENT)
|
|
||||||
|| (e->major_code == XCB_CONFIGURE_WINDOW
|
|
||||||
&& e->error_code == XCB_EVENT_ERROR_BAD_MATCH))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
warn("X error: request=%s, error=%s",
|
|
||||||
xcb_event_get_request_label(e->major_code),
|
|
||||||
xcb_event_get_error_label(e->error_code));
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Print help and exit(2) with given exit_code.
|
/** Print help and exit(2) with given exit_code.
|
||||||
* \param exit_code The exit code.
|
* \param exit_code The exit code.
|
||||||
*/
|
*/
|
||||||
|
@ -456,10 +411,6 @@ main(int argc, char **argv)
|
||||||
ev_prepare_start(globalconf.loop, &a_refresh);
|
ev_prepare_start(globalconf.loop, &a_refresh);
|
||||||
ev_unref(globalconf.loop);
|
ev_unref(globalconf.loop);
|
||||||
|
|
||||||
/* Allocate a handler which will holds all errors and events */
|
|
||||||
xcb_event_handlers_init(globalconf.connection, &globalconf.evenths);
|
|
||||||
xutil_error_handler_catch_all_set(&globalconf.evenths, xerrorstart, NULL);
|
|
||||||
|
|
||||||
for(screen_nbr = 0;
|
for(screen_nbr = 0;
|
||||||
screen_nbr < xcb_setup_roots_length(xcb_get_setup(globalconf.connection));
|
screen_nbr < xcb_setup_roots_length(xcb_get_setup(globalconf.connection));
|
||||||
screen_nbr++)
|
screen_nbr++)
|
||||||
|
@ -475,11 +426,10 @@ main(int argc, char **argv)
|
||||||
/* Need to xcb_flush to validate error handler */
|
/* Need to xcb_flush to validate error handler */
|
||||||
xcb_aux_sync(globalconf.connection);
|
xcb_aux_sync(globalconf.connection);
|
||||||
|
|
||||||
/* Process all errors in the queue if any */
|
/* Process all errors in the queue if any. There can be no events yet, so if
|
||||||
xcb_event_poll_for_event_loop(&globalconf.evenths);
|
* this function returns something, it must be an error. */
|
||||||
|
if (xcb_poll_for_event(globalconf.connection) != NULL)
|
||||||
/* Set the default xerror handler */
|
fatal("another window manager is already running");
|
||||||
xutil_error_handler_catch_all_set(&globalconf.evenths, xerror, NULL);
|
|
||||||
|
|
||||||
/* Prefetch the maximum request length */
|
/* Prefetch the maximum request length */
|
||||||
xcb_prefetch_maximum_request_length(globalconf.connection);
|
xcb_prefetch_maximum_request_length(globalconf.connection);
|
||||||
|
@ -556,11 +506,6 @@ main(int argc, char **argv)
|
||||||
/* scan existing windows */
|
/* scan existing windows */
|
||||||
scan();
|
scan();
|
||||||
|
|
||||||
/* process all errors in the queue if any */
|
|
||||||
xcb_event_poll_for_event_loop(&globalconf.evenths);
|
|
||||||
a_xcb_set_event_handlers();
|
|
||||||
a_xcb_set_property_handlers();
|
|
||||||
|
|
||||||
/* we will receive events, stop grabbing server */
|
/* we will receive events, stop grabbing server */
|
||||||
xcb_ungrab_server(globalconf.connection);
|
xcb_ungrab_server(globalconf.connection);
|
||||||
xcb_flush(globalconf.connection);
|
xcb_flush(globalconf.connection);
|
||||||
|
|
|
@ -93,16 +93,6 @@ xutil_lock_mask_get(xcb_connection_t *connection,
|
||||||
/* Number of different errors */
|
/* Number of different errors */
|
||||||
#define ERRORS_NBR 256
|
#define ERRORS_NBR 256
|
||||||
|
|
||||||
void
|
|
||||||
xutil_error_handler_catch_all_set(xcb_event_handlers_t *evenths,
|
|
||||||
xcb_generic_error_handler_t handler,
|
|
||||||
void *data)
|
|
||||||
{
|
|
||||||
int err_num;
|
|
||||||
for(err_num = 0; err_num < ERRORS_NBR; err_num++)
|
|
||||||
xcb_event_set_error_handler(evenths, err_num, handler, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
uint16_t
|
uint16_t
|
||||||
xutil_key_mask_fromstr(const char *keyname, size_t len)
|
xutil_key_mask_fromstr(const char *keyname, size_t len)
|
||||||
{
|
{
|
||||||
|
|
90
event.c
90
event.c
|
@ -27,6 +27,7 @@
|
||||||
|
|
||||||
#include "awesome.h"
|
#include "awesome.h"
|
||||||
#include "event.h"
|
#include "event.h"
|
||||||
|
#include "property.h"
|
||||||
#include "objects/tag.h"
|
#include "objects/tag.h"
|
||||||
#include "xwindow.h"
|
#include "xwindow.h"
|
||||||
#include "ewmh.h"
|
#include "ewmh.h"
|
||||||
|
@ -836,36 +837,79 @@ event_handle_reparentnotify(void *data,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void a_xcb_set_event_handlers(void)
|
/** \brief awesome xerror function.
|
||||||
|
* There's no way to check accesses to destroyed windows, thus those cases are
|
||||||
|
* ignored (especially on UnmapNotify's).
|
||||||
|
* \param e The error event.
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
xerror(xcb_generic_error_t *e)
|
||||||
{
|
{
|
||||||
const xcb_query_extension_reply_t *randr_query;
|
/* ignore this */
|
||||||
|
if(e->error_code == XCB_EVENT_ERROR_BAD_WINDOW
|
||||||
|
|| (e->error_code == XCB_EVENT_ERROR_BAD_MATCH
|
||||||
|
&& e->major_code == XCB_SET_INPUT_FOCUS)
|
||||||
|
|| (e->error_code == XCB_EVENT_ERROR_BAD_VALUE
|
||||||
|
&& e->major_code == XCB_KILL_CLIENT)
|
||||||
|
|| (e->major_code == XCB_CONFIGURE_WINDOW
|
||||||
|
&& e->error_code == XCB_EVENT_ERROR_BAD_MATCH))
|
||||||
|
return;
|
||||||
|
|
||||||
xcb_event_set_button_press_handler(&globalconf.evenths, event_handle_button, NULL);
|
warn("X error: request=%s, error=%s",
|
||||||
xcb_event_set_button_release_handler(&globalconf.evenths, event_handle_button, NULL);
|
xcb_event_get_request_label(e->major_code),
|
||||||
xcb_event_set_configure_request_handler(&globalconf.evenths, event_handle_configurerequest, NULL);
|
xcb_event_get_error_label(e->error_code));
|
||||||
xcb_event_set_configure_notify_handler(&globalconf.evenths, event_handle_configurenotify, NULL);
|
|
||||||
xcb_event_set_destroy_notify_handler(&globalconf.evenths, event_handle_destroynotify, NULL);
|
|
||||||
xcb_event_set_enter_notify_handler(&globalconf.evenths, event_handle_enternotify, NULL);
|
|
||||||
xcb_event_set_leave_notify_handler(&globalconf.evenths, event_handle_leavenotify, NULL);
|
|
||||||
xcb_event_set_focus_in_handler(&globalconf.evenths, event_handle_focusin, NULL);
|
|
||||||
xcb_event_set_motion_notify_handler(&globalconf.evenths, event_handle_motionnotify, NULL);
|
|
||||||
xcb_event_set_expose_handler(&globalconf.evenths, event_handle_expose, NULL);
|
|
||||||
xcb_event_set_key_press_handler(&globalconf.evenths, event_handle_key, NULL);
|
|
||||||
xcb_event_set_key_release_handler(&globalconf.evenths, event_handle_key, NULL);
|
|
||||||
xcb_event_set_map_request_handler(&globalconf.evenths, event_handle_maprequest, NULL);
|
|
||||||
xcb_event_set_unmap_notify_handler(&globalconf.evenths, event_handle_unmapnotify, NULL);
|
|
||||||
xcb_event_set_client_message_handler(&globalconf.evenths, event_handle_clientmessage, NULL);
|
|
||||||
xcb_event_set_mapping_notify_handler(&globalconf.evenths, event_handle_mappingnotify, NULL);
|
|
||||||
xcb_event_set_reparent_notify_handler(&globalconf.evenths, event_handle_reparentnotify, NULL);
|
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
void event_handle(xcb_generic_event_t *event)
|
||||||
|
{
|
||||||
|
uint8_t response_type = XCB_EVENT_RESPONSE_TYPE(event);
|
||||||
|
|
||||||
|
if(response_type == 0)
|
||||||
|
{
|
||||||
|
/* This is an error, not a event */
|
||||||
|
xerror((xcb_generic_error_t *) event);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(response_type)
|
||||||
|
{
|
||||||
|
#define EVENT(type, callback) case type: callback(NULL, globalconf.connection, (void *) event); return
|
||||||
|
EVENT(XCB_BUTTON_PRESS, event_handle_button);
|
||||||
|
EVENT(XCB_BUTTON_RELEASE, event_handle_button);
|
||||||
|
EVENT(XCB_CONFIGURE_REQUEST, event_handle_configurerequest);
|
||||||
|
EVENT(XCB_CONFIGURE_NOTIFY, event_handle_configurenotify);
|
||||||
|
EVENT(XCB_DESTROY_NOTIFY, event_handle_destroynotify);
|
||||||
|
EVENT(XCB_ENTER_NOTIFY, event_handle_enternotify);
|
||||||
|
EVENT(XCB_CLIENT_MESSAGE, event_handle_clientmessage);
|
||||||
|
EVENT(XCB_EXPOSE, event_handle_expose);
|
||||||
|
EVENT(XCB_FOCUS_IN, event_handle_focusin);
|
||||||
|
EVENT(XCB_KEY_PRESS, event_handle_key);
|
||||||
|
EVENT(XCB_KEY_RELEASE, event_handle_key);
|
||||||
|
EVENT(XCB_LEAVE_NOTIFY, event_handle_leavenotify);
|
||||||
|
EVENT(XCB_MAPPING_NOTIFY, event_handle_mappingnotify);
|
||||||
|
EVENT(XCB_MAP_REQUEST, event_handle_maprequest);
|
||||||
|
EVENT(XCB_MOTION_NOTIFY, event_handle_motionnotify);
|
||||||
|
EVENT(XCB_PROPERTY_NOTIFY, property_handle_propertynotify);
|
||||||
|
EVENT(XCB_REPARENT_NOTIFY, event_handle_reparentnotify);
|
||||||
|
EVENT(XCB_UNMAP_NOTIFY, event_handle_unmapnotify);
|
||||||
|
#undef EVENT
|
||||||
|
}
|
||||||
|
|
||||||
|
static uint8_t randr_screen_change_notify = 0;
|
||||||
|
|
||||||
|
if(randr_screen_change_notify == 0)
|
||||||
|
{
|
||||||
/* check for randr extension */
|
/* check for randr extension */
|
||||||
|
const xcb_query_extension_reply_t *randr_query;
|
||||||
randr_query = xcb_get_extension_data(globalconf.connection, &xcb_randr_id);
|
randr_query = xcb_get_extension_data(globalconf.connection, &xcb_randr_id);
|
||||||
if(randr_query->present)
|
if(randr_query->present)
|
||||||
xcb_event_set_handler(&globalconf.evenths,
|
randr_screen_change_notify = randr_query->first_event + XCB_RANDR_SCREEN_CHANGE_NOTIFY;
|
||||||
randr_query->first_event + XCB_RANDR_SCREEN_CHANGE_NOTIFY,
|
}
|
||||||
(xcb_generic_event_handler_t) event_handle_randr_screen_change_notify,
|
|
||||||
NULL);
|
|
||||||
|
|
||||||
|
if (response_type == randr_screen_change_notify)
|
||||||
|
event_handle_randr_screen_change_notify(NULL, globalconf.connection, (void *) event);
|
||||||
}
|
}
|
||||||
|
|
||||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
||||||
|
|
2
event.h
2
event.h
|
@ -36,7 +36,7 @@ awesome_refresh(void)
|
||||||
return xcb_flush(globalconf.connection);
|
return xcb_flush(globalconf.connection);
|
||||||
}
|
}
|
||||||
|
|
||||||
void a_xcb_set_event_handlers(void);
|
void event_handle(xcb_generic_event_t *event);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
||||||
|
|
|
@ -53,8 +53,6 @@ typedef struct
|
||||||
{
|
{
|
||||||
/** Connection ref */
|
/** Connection ref */
|
||||||
xcb_connection_t *connection;
|
xcb_connection_t *connection;
|
||||||
/** Event and error handlers */
|
|
||||||
xcb_event_handlers_t evenths;
|
|
||||||
/** Default screen number */
|
/** Default screen number */
|
||||||
int default_screen;
|
int default_screen;
|
||||||
/** Keys symbol table */
|
/** Keys symbol table */
|
||||||
|
|
10
property.c
10
property.c
|
@ -406,8 +406,8 @@ property_handle_net_wm_opacity(uint8_t state,
|
||||||
* \param ev The event.
|
* \param ev The event.
|
||||||
* \return Status code, 0 if everything's fine.
|
* \return Status code, 0 if everything's fine.
|
||||||
*/
|
*/
|
||||||
static int
|
int
|
||||||
handle_propertynotify(void *data,
|
property_handle_propertynotify(void *data,
|
||||||
xcb_connection_t *c,
|
xcb_connection_t *c,
|
||||||
xcb_property_notify_event_t *ev)
|
xcb_property_notify_event_t *ev)
|
||||||
{
|
{
|
||||||
|
@ -477,10 +477,4 @@ handle_propertynotify(void *data,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void a_xcb_set_property_handlers(void)
|
|
||||||
{
|
|
||||||
/* Register our handler for PropertyNotify events */
|
|
||||||
xcb_event_set_property_notify_handler(&globalconf.evenths, handle_propertynotify, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
||||||
|
|
|
@ -38,7 +38,10 @@ void property_update_wm_client_machine(client_t *, xcb_get_property_reply_t *);
|
||||||
void property_update_wm_window_role(client_t *, xcb_get_property_reply_t *);
|
void property_update_wm_window_role(client_t *, xcb_get_property_reply_t *);
|
||||||
void property_update_net_wm_pid(client_t *, xcb_get_property_reply_t *);
|
void property_update_net_wm_pid(client_t *, xcb_get_property_reply_t *);
|
||||||
void property_update_net_wm_icon(client_t *, xcb_get_property_reply_t *);
|
void property_update_net_wm_icon(client_t *, xcb_get_property_reply_t *);
|
||||||
void a_xcb_set_property_handlers(void);
|
|
||||||
|
int property_handle_propertynotify(void *data,
|
||||||
|
xcb_connection_t *c,
|
||||||
|
xcb_property_notify_event_t *ev);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80
|
||||||
|
|
|
@ -74,7 +74,7 @@ luaA_selection_get(lua_State *L)
|
||||||
* Anyway that's still brakes the socket or D-Bus, so maybe using
|
* Anyway that's still brakes the socket or D-Bus, so maybe using
|
||||||
* ev_loop() would be even better.
|
* ev_loop() would be even better.
|
||||||
*/
|
*/
|
||||||
xcb_event_handle(&globalconf.evenths, event);
|
event_handle(event);
|
||||||
p_delete(&event);
|
p_delete(&event);
|
||||||
awesome_refresh();
|
awesome_refresh();
|
||||||
continue;
|
continue;
|
||||||
|
|
Loading…
Reference in New Issue