diff options
author | jcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-25 23:15:41 +0000 |
---|---|---|
committer | jcampan@chromium.org <jcampan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-25 23:15:41 +0000 |
commit | c566c610480e0d8e915193c058f415a7660d48b5 (patch) | |
tree | f36460711defe77bb82f060ab1aa005a24de5475 /views | |
parent | e098ce874e942a11083116f848310d026e8c37c8 (diff) | |
download | chromium_src-c566c610480e0d8e915193c058f415a7660d48b5.zip chromium_src-c566c610480e0d8e915193c058f415a7660d48b5.tar.gz chromium_src-c566c610480e0d8e915193c058f415a7660d48b5.tar.bz2 |
[Relanding erg's change with fix for toolkit_views shortcuts and
interactive ui tests. Note that this was originally reviewed in
http://codereview.chromium.org/217022/show I originally Elliot
suggestion of replacing the usage of int for keycode with the
bae::Keycode type, but that led to the CL getting out of hands
(as this is used in many different places). So this is only the
patch set 1 of that CL, I'll replace the type in another CL]
Use windows keycodes under linux (and all non-windows platforms).
This fixes any place where we use a VKEY_* (RenderWidgetHost, for example)
under Linux, but breaks accelerators in TOOLKIT_VIEWS which relied on this
wrong behaviour.
Previously, keyboard_codes_linux defined all the VKEY_* constants as their
GDK_* counterparts, which is wrong since the VKEY_* are supposed to resolve
to windows key codes.
BUG=22551
TEST=Make sure accelerators still work as expected on Chrome Linux and
Chrome Linux with toolkit views. Test when the the accelerators with
the focus in the location bar and also with the focus on the page.
Review URL: http://codereview.chromium.org/235025
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@27284 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'views')
-rw-r--r-- | views/controls/button/custom_button.cc | 2 | ||||
-rw-r--r-- | views/event.h | 6 | ||||
-rw-r--r-- | views/event_gtk.cc | 7 | ||||
-rw-r--r-- | views/focus/accelerator_handler_gtk.cc | 2 | ||||
-rw-r--r-- | views/widget/widget_gtk.cc | 4 |
5 files changed, 13 insertions, 8 deletions
diff --git a/views/controls/button/custom_button.cc b/views/controls/button/custom_button.cc index c7eadca..e507d93 100644 --- a/views/controls/button/custom_button.cc +++ b/views/controls/button/custom_button.cc @@ -99,7 +99,7 @@ bool CustomButton::AcceleratorPressed(const Accelerator& accelerator) { gdk_key.state = (accelerator.IsAltDown() << 3) + (accelerator.IsCtrlDown() << 2) + accelerator.IsShiftDown(); - KeyEvent key_event(&gdk_key, false); + KeyEvent key_event(&gdk_key); #endif NotifyClick(key_event); return true; diff --git a/views/event.h b/views/event.h index 882f558..5a6efd9 100644 --- a/views/event.h +++ b/views/event.h @@ -244,9 +244,13 @@ class KeyEvent : public Event { // Create a new key event KeyEvent(EventType type, int ch, int repeat_count, int message_flags); #elif defined(OS_LINUX) - KeyEvent(GdkEventKey* event, bool make_lower_case); + explicit KeyEvent(GdkEventKey* event); #endif + // This returns a VKEY_ value as defined in base/keyboard_codes.h which is + // the Windows value. + // On GTK, you can use the methods in keyboard_code_conversion_gtk.cc to + // convert this value back to a GDK value if needed. int GetCharacter() const { return character_; } diff --git a/views/event_gtk.cc b/views/event_gtk.cc index 6f1e450..71fd056 100644 --- a/views/event_gtk.cc +++ b/views/event_gtk.cc @@ -6,18 +6,19 @@ #include <gdk/gdk.h> +#include "base/keyboard_code_conversion_gtk.h" + namespace views { // TODO(jcampan): the same physical key can send different keyvals (ex: a or A). // In order for accelerators to work, we need to normalize that. The right // solution should probably to get the key-code out of the keystate. -KeyEvent::KeyEvent(GdkEventKey* event, bool make_lower_case) +KeyEvent::KeyEvent(GdkEventKey* event) : Event(event->type == GDK_KEY_PRESS ? Event::ET_KEY_PRESSED : Event::ET_KEY_RELEASED, GetFlagsFromGdkState(event->state)), // TODO(erg): All these values are iffy. - character_(make_lower_case ? gdk_keyval_to_lower(event->keyval) : - event->keyval), + character_(base::WindowsKeyCodeForGdkKeyCode(event->keyval)), repeat_count_(0), message_flags_(0) { } diff --git a/views/focus/accelerator_handler_gtk.cc b/views/focus/accelerator_handler_gtk.cc index 8b52b98..bb519bb 100644 --- a/views/focus/accelerator_handler_gtk.cc +++ b/views/focus/accelerator_handler_gtk.cc @@ -43,7 +43,7 @@ bool AcceleratorHandler::Dispatch(GdkEvent* event) { } if (event->type == GDK_KEY_PRESS) { - KeyEvent view_key_event(key_event, true); + KeyEvent view_key_event(key_event); // FocusManager::OnKeyPressed and OnKeyReleased return false if this // message has been consumed and should not be propagated further. if (!focus_manager->OnKeyEvent(view_key_event)) { diff --git a/views/widget/widget_gtk.cc b/views/widget/widget_gtk.cc index 8f43603..81c214d 100644 --- a/views/widget/widget_gtk.cc +++ b/views/widget/widget_gtk.cc @@ -700,12 +700,12 @@ gboolean WidgetGtk::OnLeaveNotify(GtkWidget* widget, GdkEventCrossing* event) { } gboolean WidgetGtk::OnKeyPress(GtkWidget* widget, GdkEventKey* event) { - KeyEvent key_event(event, false); + KeyEvent key_event(event); return root_view_->ProcessKeyEvent(key_event); } gboolean WidgetGtk::OnKeyRelease(GtkWidget* widget, GdkEventKey* event) { - KeyEvent key_event(event, false); + KeyEvent key_event(event); return root_view_->ProcessKeyEvent(key_event); } |