summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-03 02:17:31 +0000
committerananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-10-03 02:17:31 +0000
commit39c32782c244ad7e2793bed305bf941b24103d1f (patch)
tree927bf5f039913c68e800e24b5808da2a72d72a1c /chrome
parent6bb27c014a169b1c34b5cc8ad45c4aad453fc779 (diff)
downloadchromium_src-39c32782c244ad7e2793bed305bf941b24103d1f.zip
chromium_src-39c32782c244ad7e2793bed305bf941b24103d1f.tar.gz
chromium_src-39c32782c244ad7e2793bed305bf941b24103d1f.tar.bz2
Pass unhandled keyup messages coming in from the renderer to the underlying view. This is needed
for system keyboard messages which are generated when the Alt key is pressed in addition to other keys to function correctly in ChromeFrame. The TabContentsView implementation for windows does the right thing by specifically checking for keydown events before processing them as accelerators. The TabContentsView implementation for Linux also treated keyup messages as accelerators, which is now fixed. This fixes parts of http://code.google.com/p/chromium/issues/detail?id=22996 Bug=22996 Review URL: http://codereview.chromium.org/255028 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@27926 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/renderer_host/render_view_host.cc9
-rw-r--r--chrome/browser/tab_contents/tab_contents_view_gtk.cc5
2 files changed, 5 insertions, 9 deletions
diff --git a/chrome/browser/renderer_host/render_view_host.cc b/chrome/browser/renderer_host/render_view_host.cc
index a778f62..e793a7b 100644
--- a/chrome/browser/renderer_host/render_view_host.cc
+++ b/chrome/browser/renderer_host/render_view_host.cc
@@ -1436,14 +1436,7 @@ void RenderViewHost::UnhandledKeyboardEvent(
const NativeWebKeyboardEvent& event) {
RenderViewHostDelegate::View* view = delegate_->GetViewDelegate();
if (view) {
- // TODO(brettw) why do we have to filter these types of events here. Can't
- // the renderer just send us the ones we care abount, or maybe the view
- // should be able to decide which ones it wants or not?
- if ((event.type == WebInputEvent::RawKeyDown) ||
- (event.type == WebInputEvent::KeyDown) ||
- (event.type == WebInputEvent::Char)) {
- view->HandleKeyboardEvent(event);
- }
+ view->HandleKeyboardEvent(event);
}
}
diff --git a/chrome/browser/tab_contents/tab_contents_view_gtk.cc b/chrome/browser/tab_contents/tab_contents_view_gtk.cc
index c85060b..f5adeec 100644
--- a/chrome/browser/tab_contents/tab_contents_view_gtk.cc
+++ b/chrome/browser/tab_contents/tab_contents_view_gtk.cc
@@ -571,7 +571,10 @@ void TabContentsViewGtk::HandleKeyboardEvent(
// |event.os_event| values are dummy values (or NULL.)
// We should filter out these pseudo key events to prevent unexpected
// behaviors caused by them.
- if (event.type == WebKit::WebInputEvent::Char)
+ // We should also filter out the KeyUp event as it should not be processed
+ // as an accelerator.
+ if (event.type == WebKit::WebInputEvent::Char ||
+ event.type == WebKit::WebInputEvent::KeyUp)
return;
BrowserWindowGtk* browser_window =