Refresh Keyboard layout when changed on Linux. Fix #72
This commit is contained in:
parent
fc74483369
commit
888e329d49
|
@ -149,14 +149,53 @@ int32_t initialize(void * _context_instance) {
|
||||||
return -5;
|
return -5;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!XRecordEnableContextAsync(data_disp, context, event_callback, NULL)) {
|
||||||
|
return -6;
|
||||||
|
}
|
||||||
|
|
||||||
xdo_context = xdo_new(NULL);
|
xdo_context = xdo_new(NULL);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Note: We might never get a MappingNotify event if the
|
||||||
|
* modifier and keymap information was never cached in Xlib.
|
||||||
|
* The next line makes sure that this happens initially.
|
||||||
|
*/
|
||||||
|
XKeysymToKeycode(ctrl_disp, XK_F1);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t eventloop() {
|
int32_t eventloop() {
|
||||||
if (!XRecordEnableContext (data_disp, context, event_callback, NULL)) {
|
bool running = true;
|
||||||
return -1;
|
|
||||||
|
int ctrl_fd = XConnectionNumber(ctrl_disp);
|
||||||
|
int data_fd = XConnectionNumber(data_disp);
|
||||||
|
|
||||||
|
while (running)
|
||||||
|
{
|
||||||
|
fd_set fds;
|
||||||
|
FD_ZERO(&fds);
|
||||||
|
FD_SET(ctrl_fd, &fds);
|
||||||
|
FD_SET(data_fd, &fds);
|
||||||
|
timeval timeout;
|
||||||
|
timeout.tv_sec = 2;
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
int retval = select(max(ctrl_fd, data_fd) + 1,
|
||||||
|
&fds, NULL, NULL, &timeout);
|
||||||
|
|
||||||
|
if (FD_ISSET(data_fd, &fds)) {
|
||||||
|
XRecordProcessReplies(data_disp);
|
||||||
|
}
|
||||||
|
if (FD_ISSET(ctrl_fd, &fds)) {
|
||||||
|
XEvent event;
|
||||||
|
XNextEvent(ctrl_disp, &event);
|
||||||
|
if (event.type == MappingNotify) {
|
||||||
|
XMappingEvent *e = (XMappingEvent *) &event;
|
||||||
|
if (e->request == MappingKeyboard) {
|
||||||
|
XRefreshKeyboardMapping(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user