summaryrefslogtreecommitdiffstats
path: root/x11vnc/keyboard.c
diff options
context:
space:
mode:
Diffstat (limited to 'x11vnc/keyboard.c')
-rw-r--r--x11vnc/keyboard.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/x11vnc/keyboard.c b/x11vnc/keyboard.c
index 29aa9f4..5f16a78 100644
--- a/x11vnc/keyboard.c
+++ b/x11vnc/keyboard.c
@@ -2235,6 +2235,7 @@ void initialize_modtweak(void) {
#else
KeySym keysym, *keymap;
int i, j, minkey, maxkey, syms_per_keycode;
+ int use_lowest_index = 0;
if (use_xkb_modtweak) {
initialize_xkb_modtweak();
@@ -2247,6 +2248,10 @@ void initialize_modtweak(void) {
RAWFB_RET_VOID
+ if (getenv("MODTWEAK_LOWEST")) {
+ use_lowest_index = 1;
+ }
+
X_LOCK;
XDisplayKeycodes(dpy, &minkey, &maxkey);
@@ -2306,6 +2311,9 @@ void initialize_modtweak(void) {
keysym = keymap[ (i - minkey) * syms_per_keycode + j ];
if ( keysym >= ' ' && keysym < 0x100
&& i == XKeysymToKeycode(dpy, keysym) ) {
+ if (use_lowest_index && keycodes[keysym] != NoSymbol) {
+ continue;
+ }
keycodes[keysym] = i;
modifiers[keysym] = j;
}
@@ -2555,6 +2563,8 @@ static void pipe_keyboard(rfbBool down, rfbKeySym keysym, rfbClientPtr client) {
uinput_key_command(down, keysym, client);
} else if (pipeinput_int == PIPEINPUT_MACOSX) {
macosx_key_command(down, keysym, client);
+ } else if (pipeinput_int == PIPEINPUT_VNC) {
+ vnc_reflect_send_key((uint32_t) keysym, down);
}
if (pipeinput_fh == NULL) {
return;