| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 // Portions based heavily on: | 5 // Portions based heavily on: |
| 6 // third_party/WebKit/public/web/gtk/WebInputEventFactory.cpp | 6 // third_party/WebKit/public/web/gtk/WebInputEventFactory.cpp |
| 7 // | 7 // |
| 8 /* | 8 /* |
| 9 * Copyright (C) 2006-2011 Google Inc. All rights reserved. | 9 * Copyright (C) 2006-2011 Google Inc. All rights reserved. |
| 10 * | 10 * |
| (...skipping 29 matching lines...) Expand all Loading... |
| 40 #include <X11/keysym.h> | 40 #include <X11/keysym.h> |
| 41 #include <X11/Xlib.h> | 41 #include <X11/Xlib.h> |
| 42 #include <X11/Xutil.h> | 42 #include <X11/Xutil.h> |
| 43 #include <cstdlib> | 43 #include <cstdlib> |
| 44 | 44 |
| 45 #include "base/event_types.h" | 45 #include "base/event_types.h" |
| 46 #include "base/logging.h" | 46 #include "base/logging.h" |
| 47 #include "content/browser/renderer_host/ui_events_helper.h" | 47 #include "content/browser/renderer_host/ui_events_helper.h" |
| 48 #include "ui/events/event.h" | 48 #include "ui/events/event.h" |
| 49 #include "ui/events/event_constants.h" | 49 #include "ui/events/event_constants.h" |
| 50 #include "ui/events/event_utils.h" |
| 50 #include "ui/events/keycodes/keyboard_code_conversion_x.h" | 51 #include "ui/events/keycodes/keyboard_code_conversion_x.h" |
| 51 #include "ui/events/keycodes/keyboard_codes.h" | 52 #include "ui/events/keycodes/keyboard_codes.h" |
| 52 | 53 |
| 53 namespace content { | 54 namespace content { |
| 54 | 55 |
| 55 // chromium WebKit does not provide a WebInputEventFactory for X11, so we have | 56 // chromium WebKit does not provide a WebInputEventFactory for X11, so we have |
| 56 // to do the work here ourselves. | 57 // to do the work here ourselves. |
| 57 | 58 |
| 58 namespace { | |
| 59 | |
| 60 int XKeyEventToWindowsKeyCode(XKeyEvent* event) { | |
| 61 int windows_key_code = | |
| 62 ui::KeyboardCodeFromXKeyEvent(reinterpret_cast<XEvent*>(event)); | |
| 63 if (windows_key_code == ui::VKEY_SHIFT || | |
| 64 windows_key_code == ui::VKEY_CONTROL || | |
| 65 windows_key_code == ui::VKEY_MENU) { | |
| 66 // To support DOM3 'location' attribute, we need to lookup an X KeySym and | |
| 67 // set ui::VKEY_[LR]XXX instead of ui::VKEY_XXX. | |
| 68 KeySym keysym = XK_VoidSymbol; | |
| 69 XLookupString(event, NULL, 0, &keysym, NULL); | |
| 70 switch (keysym) { | |
| 71 case XK_Shift_L: | |
| 72 return ui::VKEY_LSHIFT; | |
| 73 case XK_Shift_R: | |
| 74 return ui::VKEY_RSHIFT; | |
| 75 case XK_Control_L: | |
| 76 return ui::VKEY_LCONTROL; | |
| 77 case XK_Control_R: | |
| 78 return ui::VKEY_RCONTROL; | |
| 79 case XK_Meta_L: | |
| 80 case XK_Alt_L: | |
| 81 return ui::VKEY_LMENU; | |
| 82 case XK_Meta_R: | |
| 83 case XK_Alt_R: | |
| 84 return ui::VKEY_RMENU; | |
| 85 } | |
| 86 } | |
| 87 return windows_key_code; | |
| 88 } | |
| 89 | |
| 90 } // namespace | |
| 91 | |
| 92 blink::WebKeyboardEvent MakeWebKeyboardEventFromAuraEvent( | 59 blink::WebKeyboardEvent MakeWebKeyboardEventFromAuraEvent( |
| 93 ui::KeyEvent* event) { | 60 ui::KeyEvent* event) { |
| 94 const base::NativeEvent& native_event = event->native_event(); | 61 const base::NativeEvent& native_event = event->native_event(); |
| 95 blink::WebKeyboardEvent webkit_event; | 62 blink::WebKeyboardEvent webkit_event; |
| 96 XKeyEvent* native_key_event = &native_event->xkey; | 63 XKeyEvent* native_key_event = &native_event->xkey; |
| 97 | 64 |
| 98 webkit_event.timeStampSeconds = event->time_stamp().InSecondsF(); | 65 webkit_event.timeStampSeconds = event->time_stamp().InSecondsF(); |
| 99 webkit_event.modifiers = EventFlagsToWebEventModifiers(event->flags()); | 66 webkit_event.modifiers = EventFlagsToWebEventModifiers(event->flags()); |
| 100 | 67 |
| 101 switch (native_event->type) { | 68 switch (native_event->type) { |
| 102 case KeyPress: | 69 case KeyPress: |
| 103 webkit_event.type = event->is_char() ? blink::WebInputEvent::Char : | 70 webkit_event.type = event->is_char() ? blink::WebInputEvent::Char : |
| 104 blink::WebInputEvent::RawKeyDown; | 71 blink::WebInputEvent::RawKeyDown; |
| 105 break; | 72 break; |
| 106 case KeyRelease: | 73 case KeyRelease: |
| 107 webkit_event.type = blink::WebInputEvent::KeyUp; | 74 webkit_event.type = blink::WebInputEvent::KeyUp; |
| 108 break; | 75 break; |
| 109 default: | 76 default: |
| 110 NOTREACHED(); | 77 NOTREACHED(); |
| 111 } | 78 } |
| 112 | 79 |
| 113 if (webkit_event.modifiers & blink::WebInputEvent::AltKey) | 80 if (webkit_event.modifiers & blink::WebInputEvent::AltKey) |
| 114 webkit_event.isSystemKey = true; | 81 webkit_event.isSystemKey = true; |
| 115 | 82 |
| 116 webkit_event.windowsKeyCode = XKeyEventToWindowsKeyCode(native_key_event); | 83 webkit_event.windowsKeyCode = ui::WindowsKeycodeFromNative(native_event); |
| 117 webkit_event.nativeKeyCode = native_key_event->keycode; | 84 webkit_event.nativeKeyCode = native_key_event->keycode; |
| 118 | 85 webkit_event.unmodifiedText[0] = |
| 119 if (webkit_event.windowsKeyCode == ui::VKEY_RETURN) | 86 ui::UnmodifiedTextFromNative(native_event); |
| 120 webkit_event.unmodifiedText[0] = '\r'; | 87 webkit_event.text[0] = ui::TextFromNative(native_event); |
| 121 else | |
| 122 webkit_event.unmodifiedText[0] = ui::GetCharacterFromXEvent(native_event); | |
| 123 | |
| 124 if (webkit_event.modifiers & blink::WebInputEvent::ControlKey) { | |
| 125 webkit_event.text[0] = | |
| 126 GetControlCharacter( | |
| 127 webkit_event.windowsKeyCode, | |
| 128 webkit_event.modifiers & blink::WebInputEvent::ShiftKey); | |
| 129 } else { | |
| 130 webkit_event.text[0] = webkit_event.unmodifiedText[0]; | |
| 131 } | |
| 132 | 88 |
| 133 webkit_event.setKeyIdentifierFromWindowsKeyCode(); | 89 webkit_event.setKeyIdentifierFromWindowsKeyCode(); |
| 134 | 90 |
| 135 // TODO: IsKeyPad? | 91 // TODO: IsKeyPad? |
| 136 | 92 |
| 137 return webkit_event; | 93 return webkit_event; |
| 138 } | 94 } |
| 139 | 95 |
| 140 } // namespace content | 96 } // namespace content |
| OLD | NEW |