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

Side by Side Diff: ash/accelerators/accelerator_dispatcher_win.cc

Issue 9224001: Fixes issue with accelerators when a menu is open (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Nicer diff Created 8 years, 10 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
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "ash/accelerators/accelerator_dispatcher.h"
6
7 #include "ash/accelerators/accelerator_controller.h"
8 #include "ash/shell.h"
9 #include "base/message_loop.h"
10 #include "base/message_pump_win.h"
11 #include "ui/aura/event.h"
12 #include "ui/base/accelerators/accelerator.h"
13
14 namespace ash {
15
16 namespace {
17
18 const int kModifierMask = (ui::EF_SHIFT_DOWN |
19 ui::EF_CONTROL_DOWN |
20 ui::EF_ALT_DOWN);
21 } // namespace
22
23 bool AcceleratorDispatcher::Dispatch(const MSG& msg) {
24 ash::Shell* shell = ash::Shell::GetInstance();
25 if (shell->IsScreenLocked())
26 return true;
oshima 2012/01/31 18:19:52 ditto
27
28 if(msg.message == WM_KEYDOWN || msg.message == WM_SYSKEYDOWN) {
29 ash::AcceleratorController* accelerator_controller =
30 shell->accelerator_controller();
31 ui::Accelerator accelerator(ui::KeyboardCodeFromNative(msg),
32 ui::EventFlagsFromNative(msg) & kModifierMask);
33 if (accelerator_controller && accelerator_controller->Process(accelerator))
34 return true;
35 }
36
37 return nested_dispatcher_->Dispatch(msg);
38 }
39
40 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698