diff options
Diffstat (limited to 'remoting/host/event_executor_linux.cc')
-rw-r--r-- | remoting/host/event_executor_linux.cc | 60 |
1 files changed, 32 insertions, 28 deletions
diff --git a/remoting/host/event_executor_linux.cc b/remoting/host/event_executor_linux.cc index 77da48b..9f97ee8 100644 --- a/remoting/host/event_executor_linux.cc +++ b/remoting/host/event_executor_linux.cc @@ -5,6 +5,7 @@ #include "remoting/host/event_executor_linux.h" #include <X11/Xlib.h> +#include <X11/XF86keysym.h> #include <X11/keysym.h> #include <X11/extensions/XTest.h> @@ -36,8 +37,17 @@ static int MouseButtonToX11ButtonNumber( } } -// TODO(ajwong): Move this to a central keycodes translation file. -const int kPepperToX11Keysym[256] = { +// Hard-coded mapping from Virtual Key codes to X11 KeySyms. +// This mapping is only valid if both client and host are using a +// US English keyboard layout. +// Because we're passing VK codes on the wire, with no Scancode, +// "extended" flag, etc, things like distinguishing left & right +// Shift keys doesn't work. +// +// TODO(wez): Replace this with something more closely tied to what +// WebInputEventFactory does on Linux/GTK, and which respects the +// host's keyboard layout. +const int kUsVkeyToKeysym[256] = { // 0x00 - 0x07 -1, -1, -1, -1, // 0x04 - 0x07 @@ -48,23 +58,22 @@ const int kPepperToX11Keysym[256] = { XK_Clear, XK_Return, -1, -1, // 0x10 - 0x13 - XK_Shift_L, XK_Control_L, XK_Menu, XK_Pause, + XK_Shift_L, XK_Control_L, XK_Alt_L, XK_Pause, // 0x14 - 0x17 - /* VKEY_CAPITAL */ -1, XK_Kana_Shift, -1, /* VKEY_JUNJA */ -1, + XK_Caps_Lock, XK_Kana_Shift, -1, /* VKEY_JUNJA */ -1, // 0x18 - 0x1B /* VKEY_FINAL */ -1, XK_Kanji, -1, XK_Escape, // 0x1C - 0x1F - /* VKEY_CONVERT */ -1, /* VKEY_NONCONVERT */ -1, /* VKEY_ACCEPT */ -1, - XK_Mode_switch, + XK_Henkan, XK_Muhenkan, /* VKEY_ACCEPT */ -1, XK_Mode_switch, // 0x20 - 0x23 XK_space, XK_Prior, XK_Next, XK_End, // 0x24 - 0x27 XK_Home, XK_Left, XK_Up, XK_Right, // 0x28 - 0x2B - XK_Down, XK_Select, XK_Print, XK_Execute, + XK_Down, XK_Select, /* VK_PRINT */ -1, XK_Execute, // 0x2C - 0x2F - /* VKEY_SNAPSHOT */ -1, XK_Insert, XK_Delete, XK_Help, + XK_Print, XK_Insert, XK_Delete, XK_Help, // 0x30 - 0x33 XK_0, XK_1, XK_2, XK_3, @@ -76,7 +85,7 @@ const int kPepperToX11Keysym[256] = { -1, -1, -1, -1, // 0x40 - 0x43 - XK_0, XK_A, XK_B, XK_C, + -1, XK_A, XK_B, XK_C, // 0x44 - 0x47 XK_D, XK_E, XK_F, XK_G, // 0x48 - 0x4B @@ -89,9 +98,9 @@ const int kPepperToX11Keysym[256] = { // 0x54 - 0x57 XK_T, XK_U, XK_V, XK_W, // 0x58 - 0x5B - XK_X, XK_Y, XK_Z, XK_Meta_L, + XK_X, XK_Y, XK_Z, XK_Super_L, // 0x5C - 0x5F - XK_Meta_R, /* VKEY_APPS */ -1, -1, /* VKEY_SLEEP */-1, + XK_Super_R, XK_Menu, -1, /* VKEY_SLEEP */-1, // 0x60 - 0x63 XK_KP_0, XK_KP_1, XK_KP_2, XK_KP_3, @@ -132,29 +141,24 @@ const int kPepperToX11Keysym[256] = { // 0xA0 - 0xA3 XK_Num_Lock, XK_Scroll_Lock, XK_Control_L, XK_Control_R, // 0xA4 - 0xA7 - XK_Meta_L, XK_Meta_R, /* VKEY_BROWSER_BACK */ -1, - /* VKEY_BROWSER_FORWARD */ -1, + XK_Meta_L, XK_Meta_R, XF86XK_Back, XF86XK_Forward, // 0xA8 - 0xAB - /* VKEY_BROWSER_REFRESH */ -1, /* VKEY_BROWSER_STOP */ -1, - /* VKEY_BROWSER_SEARCH */ -1, /* VKEY_BROWSER_FAVORITES */ -1, + XF86XK_Refresh, XF86XK_Stop, XF86XK_Search, XF86XK_Favorites, // 0xAC - 0xAF - /* VKEY_BROWSER_HOME */ -1, /* VKEY_VOLUME_MUTE */ -1, - /* VKEY_VOLUME_DOWN */ -1, /* VKEY_VOLUME_UP */ -1, + XF86XK_HomePage, XF86XK_AudioMute, XF86XK_AudioLowerVolume, + XF86XK_AudioRaiseVolume, // 0xB0 - 0xB3 - /* VKEY_MEDIA_NEXT_TRACK */ -1, /* VKEY_MEDIA_PREV_TRACK */ -1, - /* VKEY_MEDIA_STOP */ -1, /* VKEY_MEDIA_PLAY_PAUSE */ -1, + XF86XK_AudioNext, XF86XK_AudioPrev, XF86XK_AudioStop, XF86XK_AudioPause, // 0xB4 - 0xB7 - /* VKEY_MEDIA_LAUNCH_MAIL */ -1, /* VKEY_MEDIA_LAUNCH_MEDIA_SELECT */ -1, - /* VKEY_MEDIA_LAUNCH_APP1 */ -1, /* VKEY_MEDIA_MEDIA_LAUNCH_APP2 */ -1, + XF86XK_Mail, XF86XK_AudioMedia, XF86XK_Launch0, XF86XK_Launch1, // 0xB8 - 0xBB - -1, -1, /* VKEY_OEM_1 */ -1, /* VKEY_OEM_PLUS */ -1, + -1, -1, XK_semicolon, XK_plus, // 0xBC - 0xBF - /* VKEY_OEM_COMMA */ -1, /* VKEY_OEM_MINUS */ -1, - /* VKEY_OEM_PERIOD */ -1, /* VKEY_OEM_2 */ -1, + XK_comma, XK_minus, XK_period, XK_slash, // 0xC0 - 0xC3 - /* VKEY_OEM_3 */ -1, -1, -1, -1, + XK_grave, -1, -1, -1, // 0xC4 - 0xC7 -1, -1, -1, -1 // 0xC8 - 0xCB @@ -167,9 +171,9 @@ const int kPepperToX11Keysym[256] = { // 0xD4 - 0xD7 -1, -1, -1, -1 // 0xD8 - 0xDB - -1, -1, -1, /* VKEY_OEM_4 */ -1, + -1, -1, -1, XK_bracketleft, // 0xDC - 0xDF - /* VKEY_OEM_5 */ -1, /* VKEY_OEM_6 */ -1, /* VKEY_OEM_7 */ -1, + XK_backslash, XK_bracketright, XK_apostrophe, /* VKEY_OEM_8 */ -1, // 0xE0 - 0xE3 @@ -197,7 +201,7 @@ static int ChromotocolKeycodeToX11Keysym(int32_t keycode) { return -1; } - return kPepperToX11Keysym[keycode]; + return kUsVkeyToKeysym[keycode]; } class EventExecutorLinuxPimpl { |