event: matching function can get data
This allows us to not request keysym computation upon each match test. Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
parent
e2b4fae3e2
commit
efad1b9843
40
event.c
40
event.c
|
@ -46,10 +46,11 @@
|
||||||
static void \
|
static void \
|
||||||
event_##xcbtype##_callback(xcb_##xcbtype##_press_event_t *ev, \
|
event_##xcbtype##_callback(xcb_##xcbtype##_press_event_t *ev, \
|
||||||
arraytype *arr, \
|
arraytype *arr, \
|
||||||
int nargs) \
|
int nargs, \
|
||||||
|
void *data) \
|
||||||
{ \
|
{ \
|
||||||
foreach(item, *arr) \
|
foreach(item, *arr) \
|
||||||
if(match(ev, *item)) \
|
if(match(ev, *item, data)) \
|
||||||
switch(ev->response_type) \
|
switch(ev->response_type) \
|
||||||
{ \
|
{ \
|
||||||
case xcbeventprefix##_PRESS: \
|
case xcbeventprefix##_PRESS: \
|
||||||
|
@ -73,20 +74,17 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
event_button_match(xcb_button_press_event_t *ev, button_t *b)
|
event_button_match(xcb_button_press_event_t *ev, button_t *b, void *data)
|
||||||
{
|
{
|
||||||
return ((!b->button || ev->detail == b->button)
|
return ((!b->button || ev->detail == b->button)
|
||||||
&& (b->mod == XCB_BUTTON_MASK_ANY || b->mod == ev->state));
|
&& (b->mod == XCB_BUTTON_MASK_ANY || b->mod == ev->state));
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
event_key_match(xcb_key_press_event_t *ev, keyb_t *k)
|
event_key_match(xcb_key_press_event_t *ev, keyb_t *k, void *data)
|
||||||
{
|
{
|
||||||
/* get keysym ignoring shift and mod5 */
|
assert(data);
|
||||||
xcb_keysym_t keysym =
|
xcb_keysym_t keysym = *(xcb_keysym_t *) data;
|
||||||
key_getkeysym(ev->detail,
|
|
||||||
ev->state & ~(XCB_MOD_MASK_SHIFT | XCB_MOD_MASK_5 | XCB_MOD_MASK_LOCK));
|
|
||||||
|
|
||||||
return (((k->keycode && ev->detail == k->keycode)
|
return (((k->keycode && ev->detail == k->keycode)
|
||||||
|| (k->keysym && keysym == k->keysym))
|
|| (k->keysym && keysym == k->keysym))
|
||||||
&& (k->mod == XCB_BUTTON_MASK_ANY || k->mod == ev->state));
|
&& (k->mod == XCB_BUTTON_MASK_ANY || k->mod == ev->state));
|
||||||
|
@ -151,7 +149,7 @@ event_handle_button(void *data, xcb_connection_t *connection, xcb_button_press_e
|
||||||
}
|
}
|
||||||
|
|
||||||
wibox_push(globalconf.L, wibox);
|
wibox_push(globalconf.L, wibox);
|
||||||
event_button_callback(ev, &wibox->buttons, 1);
|
event_button_callback(ev, &wibox->buttons, 1, NULL);
|
||||||
|
|
||||||
/* then try to match a widget binding */
|
/* then try to match a widget binding */
|
||||||
widget_t *w = widget_getbycoords(wibox->position, &wibox->widgets,
|
widget_t *w = widget_getbycoords(wibox->position, &wibox->widgets,
|
||||||
|
@ -161,7 +159,7 @@ event_handle_button(void *data, xcb_connection_t *connection, xcb_button_press_e
|
||||||
if(w)
|
if(w)
|
||||||
{
|
{
|
||||||
widget_push(globalconf.L, w);
|
widget_push(globalconf.L, w);
|
||||||
event_button_callback(ev, &w->buttons, 1);
|
event_button_callback(ev, &w->buttons, 1, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* return even if no widget match */
|
/* return even if no widget match */
|
||||||
|
@ -170,7 +168,7 @@ event_handle_button(void *data, xcb_connection_t *connection, xcb_button_press_e
|
||||||
else if((c = client_getbywin(ev->event)))
|
else if((c = client_getbywin(ev->event)))
|
||||||
{
|
{
|
||||||
client_push(globalconf.L, c);
|
client_push(globalconf.L, c);
|
||||||
event_button_callback(ev, &c->buttons, 1);
|
event_button_callback(ev, &c->buttons, 1, NULL);
|
||||||
xcb_allow_events(globalconf.connection,
|
xcb_allow_events(globalconf.connection,
|
||||||
XCB_ALLOW_REPLAY_POINTER,
|
XCB_ALLOW_REPLAY_POINTER,
|
||||||
XCB_CURRENT_TIME);
|
XCB_CURRENT_TIME);
|
||||||
|
@ -179,7 +177,7 @@ event_handle_button(void *data, xcb_connection_t *connection, xcb_button_press_e
|
||||||
for(screen = 0; screen < nb_screen; screen++)
|
for(screen = 0; screen < nb_screen; screen++)
|
||||||
if(xutil_screen_get(connection, screen)->root == ev->event)
|
if(xutil_screen_get(connection, screen)->root == ev->event)
|
||||||
{
|
{
|
||||||
event_button_callback(ev, &globalconf.buttons, 0);
|
event_button_callback(ev, &globalconf.buttons, 0, NULL);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -593,8 +591,6 @@ event_handle_key(void *data __attribute__ ((unused)),
|
||||||
xcb_connection_t *connection __attribute__ ((unused)),
|
xcb_connection_t *connection __attribute__ ((unused)),
|
||||||
xcb_key_press_event_t *ev)
|
xcb_key_press_event_t *ev)
|
||||||
{
|
{
|
||||||
client_t *c;
|
|
||||||
|
|
||||||
if(globalconf.keygrabber != LUA_REFNIL)
|
if(globalconf.keygrabber != LUA_REFNIL)
|
||||||
{
|
{
|
||||||
lua_rawgeti(globalconf.L, LUA_REGISTRYINDEX, globalconf.keygrabber);
|
lua_rawgeti(globalconf.L, LUA_REGISTRYINDEX, globalconf.keygrabber);
|
||||||
|
@ -610,13 +606,21 @@ event_handle_key(void *data __attribute__ ((unused)),
|
||||||
}
|
}
|
||||||
lua_pop(globalconf.L, 1); /* pop returned value or function if not called */
|
lua_pop(globalconf.L, 1); /* pop returned value or function if not called */
|
||||||
}
|
}
|
||||||
else if((c = client_getbywin(ev->event)))
|
else
|
||||||
|
{
|
||||||
|
/* get keysym ignoring shift and mod5 */
|
||||||
|
xcb_keysym_t keysym =
|
||||||
|
key_getkeysym(ev->detail,
|
||||||
|
ev->state & ~(XCB_MOD_MASK_SHIFT | XCB_MOD_MASK_5 | XCB_MOD_MASK_LOCK));
|
||||||
|
client_t *c;
|
||||||
|
if((c = client_getbywin(ev->event)))
|
||||||
{
|
{
|
||||||
client_push(globalconf.L, c);
|
client_push(globalconf.L, c);
|
||||||
event_key_callback(ev, &c->keys, 1);
|
event_key_callback(ev, &c->keys, 1, &keysym);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
event_key_callback(ev, &globalconf.keys, 0);
|
event_key_callback(ev, &globalconf.keys, 0, &keysym);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue