Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(366)

Side by Side Diff: content/browser/renderer_host/web_input_event_aurax11.cc

Issue 492863002: mojo: Plumb through sufficient context to make real blink::WebInputEvents. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: final sky nits Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « content/browser/renderer_host/web_input_event_aura.cc ('k') | mojo/mojo_services.gypi » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
OLDNEW
« no previous file with comments | « content/browser/renderer_host/web_input_event_aura.cc ('k') | mojo/mojo_services.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698