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

Unified Diff: views/events/event_x.cc

Issue 8380033: aura: Fix shift/ctrl/alt keyevents with RWHVA and X11. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: . Created 9 years, 2 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/base/keycodes/keyboard_code_conversion_x.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: views/events/event_x.cc
diff --git a/views/events/event_x.cc b/views/events/event_x.cc
index 1c1c51d8c0f20a88633fbbe744fe76be7833160b..edf48e9da6224c7aa1203da6c473fc6e3896a674 100644
--- a/views/events/event_x.cc
+++ b/views/events/event_x.cc
@@ -20,16 +20,6 @@ namespace views {
namespace {
-uint16 GetCharacterFromXKeyEvent(XKeyEvent* key) {
- char buf[6];
- int bytes_written = XLookupString(key, buf, 6, NULL, NULL);
- DCHECK_LE(bytes_written, 6);
-
- string16 result;
- return (bytes_written > 0 && UTF8ToUTF16(buf, bytes_written, &result) &&
- result.length() == 1) ? result[0] : 0;
-}
-
// The following two functions are copied from event_gtk.cc. These will be
// removed when GTK dependency is removed.
#if defined(TOOLKIT_USES_GTK)
@@ -72,7 +62,7 @@ uint16 KeyEvent::GetCharacter() const {
DCHECK(native_event()->type == KeyPress ||
native_event()->type == KeyRelease);
- uint16 ch = GetCharacterFromXKeyEvent(&native_event()->xkey);
+ uint16 ch = ui::DefaultSymbolFromXEvent(native_event());
return ch ? ch : GetCharacterFromKeyCode(key_code_, flags());
}
@@ -110,15 +100,15 @@ uint16 KeyEvent::GetUnmodifiedCharacter() const {
DCHECK(native_event()->type == KeyPress ||
native_event()->type == KeyRelease);
- XKeyEvent key = native_event()->xkey;
+ XKeyEvent *key = &native_event()->xkey;
static const unsigned int kIgnoredModifiers = ControlMask | LockMask |
Mod1Mask | Mod2Mask | Mod3Mask | Mod4Mask | Mod5Mask;
// We can't use things like (key.state & ShiftMask), as it may mask out bits
// used by X11 internally.
- key.state &= ~kIgnoredModifiers;
- uint16 ch = GetCharacterFromXKeyEvent(&key);
+ key->state &= ~kIgnoredModifiers;
+ uint16 ch = ui::DefaultSymbolFromXEvent(native_event());
return ch ? ch :
GetCharacterFromKeyCode(key_code_, flags() & ui::EF_SHIFT_DOWN);
}
« no previous file with comments | « ui/base/keycodes/keyboard_code_conversion_x.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698