|
|
@ -276,6 +276,16 @@ leavenotify(XEvent *e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
|
|
|
mappingnotify(XEvent *e)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
XMappingEvent *ev = &e->xmapping;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
XRefreshKeyboardMapping(ev);
|
|
|
|
|
|
|
|
if(ev->request == MappingKeyboard)
|
|
|
|
|
|
|
|
grabkeys();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
static void
|
|
|
|
maprequest(XEvent *e)
|
|
|
|
maprequest(XEvent *e)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -348,6 +358,7 @@ void (*handler[LASTEvent]) (XEvent *) = {
|
|
|
|
[LeaveNotify] = leavenotify,
|
|
|
|
[LeaveNotify] = leavenotify,
|
|
|
|
[Expose] = expose,
|
|
|
|
[Expose] = expose,
|
|
|
|
[KeyPress] = keypress,
|
|
|
|
[KeyPress] = keypress,
|
|
|
|
|
|
|
|
[MappingNotify] = mappingnotify,
|
|
|
|
[MapRequest] = maprequest,
|
|
|
|
[MapRequest] = maprequest,
|
|
|
|
[PropertyNotify] = propertynotify,
|
|
|
|
[PropertyNotify] = propertynotify,
|
|
|
|
[UnmapNotify] = unmapnotify
|
|
|
|
[UnmapNotify] = unmapnotify
|
|
|
@ -360,6 +371,7 @@ grabkeys()
|
|
|
|
unsigned int i;
|
|
|
|
unsigned int i;
|
|
|
|
KeyCode code;
|
|
|
|
KeyCode code;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
XUngrabKey(dpy, AnyKey, AnyModifier, root);
|
|
|
|
for(i = 0; i < len; i++) {
|
|
|
|
for(i = 0; i < len; i++) {
|
|
|
|
code = XKeysymToKeycode(dpy, key[i].keysym);
|
|
|
|
code = XKeysymToKeycode(dpy, key[i].keysym);
|
|
|
|
XGrabKey(dpy, code, key[i].mod, root, True,
|
|
|
|
XGrabKey(dpy, code, key[i].mod, root, True,
|
|
|
|