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

Side by Side Diff: ui/wm/core/nested_accelerator_dispatcher_linux.cc

Issue 298703007: Refactor and move ash independent nested accelerator code to ui/wm/core (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: skip test if platform does not support PES Created 6 years, 6 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
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #include "ash/accelerators/accelerator_dispatcher.h" 5 #include "ui/wm/core/nested_accelerator_dispatcher.h"
6 6
7 #include "base/memory/scoped_ptr.h" 7 #include "base/memory/scoped_ptr.h"
8 #include "base/run_loop.h" 8 #include "base/run_loop.h"
9 #include "ui/events/event.h" 9 #include "ui/events/event.h"
10 #include "ui/events/platform/platform_event_dispatcher.h" 10 #include "ui/events/platform/platform_event_dispatcher.h"
11 #include "ui/events/platform/platform_event_source.h" 11 #include "ui/events/platform/platform_event_source.h"
12 #include "ui/events/platform/scoped_event_dispatcher.h" 12 #include "ui/events/platform/scoped_event_dispatcher.h"
13 #include "ui/wm/core/nested_accelerator_delegate.h"
13 14
14 #if defined(USE_X11) 15 #if defined(USE_X11)
15 #include <X11/Xlib.h> 16 #include <X11/Xlib.h>
16 #endif 17 #endif
17 18
18 namespace ash { 19 namespace wm {
19 20
20 namespace { 21 namespace {
21 22
22 #if defined(USE_OZONE) 23 #if defined(USE_OZONE)
23 bool IsKeyEvent(const base::NativeEvent& native_event) { 24 bool IsKeyEvent(const base::NativeEvent& native_event) {
24 const ui::KeyEvent* event = static_cast<const ui::KeyEvent*>(native_event); 25 const ui::KeyEvent* event = static_cast<const ui::KeyEvent*>(native_event);
25 return event->IsKeyEvent(); 26 return event->IsKeyEvent();
26 } 27 }
27 #elif defined(USE_X11) 28 #elif defined(USE_X11)
28 bool IsKeyEvent(const XEvent* xev) { 29 bool IsKeyEvent(const XEvent* xev) {
29 return xev->type == KeyPress || xev->type == KeyRelease; 30 return xev->type == KeyPress || xev->type == KeyRelease;
30 } 31 }
31 #else 32 #else
32 #error Unknown build platform: you should have either use_ozone or use_x11. 33 #error Unknown build platform: you should have either use_ozone or use_x11.
33 #endif 34 #endif
34 35
35 scoped_ptr<ui::ScopedEventDispatcher> OverrideDispatcher( 36 scoped_ptr<ui::ScopedEventDispatcher> OverrideDispatcher(
36 ui::PlatformEventDispatcher* dispatcher) { 37 ui::PlatformEventDispatcher* dispatcher) {
37 ui::PlatformEventSource* source = ui::PlatformEventSource::GetInstance(); 38 ui::PlatformEventSource* source = ui::PlatformEventSource::GetInstance();
38 return source ? source->OverrideDispatcher(dispatcher) 39 return source ? source->OverrideDispatcher(dispatcher)
39 : scoped_ptr<ui::ScopedEventDispatcher>(); 40 : scoped_ptr<ui::ScopedEventDispatcher>();
40 } 41 }
41 42
42 } // namespace 43 } // namespace
43 44
44 class AcceleratorDispatcherLinux : public AcceleratorDispatcher, 45 class NestedAcceleratorDispatcherLinux : public NestedAcceleratorDispatcher,
45 public ui::PlatformEventDispatcher { 46 public ui::PlatformEventDispatcher {
46 public: 47 public:
47 AcceleratorDispatcherLinux() 48 explicit NestedAcceleratorDispatcherLinux(NestedAcceleratorDelegate* delegate)
48 : restore_dispatcher_(OverrideDispatcher(this)) {} 49 : NestedAcceleratorDispatcher(delegate),
50 restore_dispatcher_(OverrideDispatcher(this)) {}
49 51
50 virtual ~AcceleratorDispatcherLinux() {} 52 virtual ~NestedAcceleratorDispatcherLinux() {}
51 53
52 private: 54 private:
53 // AcceleratorDispatcher: 55 // AcceleratorDispatcher:
54 virtual scoped_ptr<base::RunLoop> CreateRunLoop() OVERRIDE { 56 virtual scoped_ptr<base::RunLoop> CreateRunLoop() OVERRIDE {
55 return scoped_ptr<base::RunLoop>(new base::RunLoop()); 57 return scoped_ptr<base::RunLoop>(new base::RunLoop());
56 } 58 }
57 59
58 // ui::PlatformEventDispatcher: 60 // ui::PlatformEventDispatcher:
59 virtual bool CanDispatchEvent(const ui::PlatformEvent& event) OVERRIDE { 61 virtual bool CanDispatchEvent(const ui::PlatformEvent& event) OVERRIDE {
60 return true; 62 return true;
61 } 63 }
62 64
63 virtual uint32_t DispatchEvent(const ui::PlatformEvent& event) OVERRIDE { 65 virtual uint32_t DispatchEvent(const ui::PlatformEvent& event) OVERRIDE {
64 if (IsKeyEvent(event)) { 66 if (IsKeyEvent(event)) {
65 ui::KeyEvent key_event(event, false); 67 ui::KeyEvent key_event(event, false);
66 if (MenuClosedForPossibleAccelerator(key_event)) { 68 if (!delegate_->ShouldProcessEventNow(key_event)) {
67 #if defined(USE_X11) 69 #if defined(USE_X11)
68 XPutBackEvent(event->xany.display, event); 70 XPutBackEvent(event->xany.display, event);
69 #else 71 #else
70 NOTIMPLEMENTED(); 72 NOTIMPLEMENTED();
71 #endif 73 #endif
72 return ui::POST_DISPATCH_NONE; 74 return ui::POST_DISPATCH_NONE;
73 } 75 }
74 76
75 if (AcceleratorProcessedForKeyEvent(key_event)) 77 if (delegate_->ProcessEvent(key_event))
76 return ui::POST_DISPATCH_NONE; 78 return ui::POST_DISPATCH_NONE;
77 } 79 }
80 ui::PlatformEventDispatcher* prev = *restore_dispatcher_;
78 81
79 ui::PlatformEventDispatcher* prev = *restore_dispatcher_;
80 return prev ? prev->DispatchEvent(event) 82 return prev ? prev->DispatchEvent(event)
81 : ui::POST_DISPATCH_PERFORM_DEFAULT; 83 : ui::POST_DISPATCH_PERFORM_DEFAULT;
82 } 84 }
83 85
84 scoped_ptr<ui::ScopedEventDispatcher> restore_dispatcher_; 86 scoped_ptr<ui::ScopedEventDispatcher> restore_dispatcher_;
85 87
86 DISALLOW_COPY_AND_ASSIGN(AcceleratorDispatcherLinux); 88 DISALLOW_COPY_AND_ASSIGN(NestedAcceleratorDispatcherLinux);
87 }; 89 };
88 90
89 scoped_ptr<AcceleratorDispatcher> AcceleratorDispatcher::Create( 91 scoped_ptr<NestedAcceleratorDispatcher> NestedAcceleratorDispatcher::Create(
92 NestedAcceleratorDelegate* delegate,
90 base::MessagePumpDispatcher* nested_dispatcher) { 93 base::MessagePumpDispatcher* nested_dispatcher) {
91 return scoped_ptr<AcceleratorDispatcher>(new AcceleratorDispatcherLinux()); 94 return scoped_ptr<NestedAcceleratorDispatcher>(
95 new NestedAcceleratorDispatcherLinux(delegate));
92 } 96 }
93 97
94 } // namespace ash 98 } // namespace wm
OLDNEW
« no previous file with comments | « ui/wm/core/nested_accelerator_dispatcher.cc ('k') | ui/wm/core/nested_accelerator_dispatcher_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698