Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 #ifndef ASH_MUS_ACCELERATORS_ACCELERATOR_CONTROLLER_REGISTRAR_H_ | 5 #ifndef ASH_MUS_ACCELERATORS_ACCELERATOR_CONTROLLER_REGISTRAR_H_ |
| 6 #define ASH_MUS_ACCELERATORS_ACCELERATOR_CONTROLLER_REGISTRAR_H_ | 6 #define ASH_MUS_ACCELERATORS_ACCELERATOR_CONTROLLER_REGISTRAR_H_ |
| 7 | 7 |
| 8 #include <stdint.h> | 8 #include <stdint.h> |
| 9 | 9 |
| 10 #include <map> | 10 #include <map> |
| 11 #include <vector> | |
| 11 | 12 |
| 12 #include "ash/mus/accelerators/accelerator_handler.h" | 13 #include "ash/mus/accelerators/accelerator_handler.h" |
| 13 #include "base/macros.h" | 14 #include "base/macros.h" |
| 14 #include "ui/base/accelerators/accelerator.h" | 15 #include "ui/base/accelerators/accelerator.h" |
| 15 #include "ui/base/accelerators/accelerator_manager_delegate.h" | 16 #include "ui/base/accelerators/accelerator_manager_delegate.h" |
| 16 #include "ui/events/mojo/event_constants.mojom.h" | 17 #include "ui/events/mojo/event_constants.mojom.h" |
| 17 | 18 |
| 18 namespace ash { | 19 namespace ash { |
| 19 | 20 |
| 20 class AcceleratorRouter; | 21 class AcceleratorRouter; |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 31 public ui::AcceleratorManagerDelegate { | 32 public ui::AcceleratorManagerDelegate { |
| 32 public: | 33 public: |
| 33 AcceleratorControllerRegistrar(WindowManager* window_manager, | 34 AcceleratorControllerRegistrar(WindowManager* window_manager, |
| 34 uint16_t id_namespace); | 35 uint16_t id_namespace); |
| 35 ~AcceleratorControllerRegistrar() override; | 36 ~AcceleratorControllerRegistrar() override; |
| 36 | 37 |
| 37 // AcceleratorHandler: | 38 // AcceleratorHandler: |
| 38 ui::mojom::EventResult OnAccelerator(uint32_t id, | 39 ui::mojom::EventResult OnAccelerator(uint32_t id, |
| 39 const ui::Event& event) override; | 40 const ui::Event& event) override; |
| 40 | 41 |
| 41 // ui::AcceleratorManagerDelegate: | 42 // ui::AcceleratorManagerDelegate: |
|
mfomitchev
2017/01/03 19:54:35
Can this be moved to private? Or no?
thanhph1
2017/01/06 21:55:56
Done, yes! I moved these 2 functions to private se
| |
| 42 void OnAcceleratorRegistered(const ui::Accelerator& accelerator) override; | 43 void OnAcceleratorRegistered(const ui::Accelerator& accelerator) override; |
| 43 void OnAcceleratorUnregistered(const ui::Accelerator& accelerator) override; | 44 void OnAcceleratorUnregistered(const ui::Accelerator& accelerator) override; |
| 44 | 45 |
| 46 void OnAcceleratorsRegistered( | |
| 47 const std::vector<ui::Accelerator>& accelerators) override; | |
| 48 | |
| 45 private: | 49 private: |
| 50 // Add accelerator with newly generated id to accelerator vector. | |
|
mfomitchev
2017/01/03 19:54:35
IMHO "newly generated id" is a bit ambiguous, beca
thanhph1
2017/01/06 21:55:56
Done, thanks! Please review my new comment.
| |
| 51 void AddAcceleratorToVector( | |
| 52 const ui::Accelerator& accelerator, | |
| 53 std::vector<ui::mojom::AcceleratorPtr>& accelerator_vector); | |
| 54 | |
| 46 friend class AcceleratorControllerRegistrarTestApi; | 55 friend class AcceleratorControllerRegistrarTestApi; |
| 47 | 56 |
| 48 // The flow of accelerators in ash is: | 57 // The flow of accelerators in ash is: |
| 49 // . wm::AcceleratorFilter() sees events first as it's a pre-target handler. | 58 // . wm::AcceleratorFilter() sees events first as it's a pre-target handler. |
| 50 // . AcceleratorFilter forwards to its delegate, which indirectly is | 59 // . AcceleratorFilter forwards to its delegate, which indirectly is |
| 51 // implemented by AcceleratorRouter. | 60 // implemented by AcceleratorRouter. |
| 52 // . AcceleratorRouter may early out, if not it calls through to | 61 // . AcceleratorRouter may early out, if not it calls through to |
| 53 // AcceleratorController. This stop may stop propagation entirely. | 62 // AcceleratorController. This stop may stop propagation entirely. |
| 54 // . If focus is on a Widget, then NativeWidgetAura gets the key event, calls | 63 // . If focus is on a Widget, then NativeWidgetAura gets the key event, calls |
| 55 // to Widget::OnKeyEvent(), which calls to FocusManager::OnKeyEvent(), which | 64 // to Widget::OnKeyEvent(), which calls to FocusManager::OnKeyEvent(), which |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 79 | 88 |
| 80 WindowManager* window_manager_; | 89 WindowManager* window_manager_; |
| 81 | 90 |
| 82 const uint16_t id_namespace_; | 91 const uint16_t id_namespace_; |
| 83 | 92 |
| 84 // Id to use for the next accelerator. | 93 // Id to use for the next accelerator. |
| 85 uint16_t next_id_; | 94 uint16_t next_id_; |
| 86 | 95 |
| 87 std::unique_ptr<AcceleratorRouter> router_; | 96 std::unique_ptr<AcceleratorRouter> router_; |
| 88 | 97 |
| 98 std::vector<ui::mojom::AcceleratorPtr> accelerator_ptrs_; | |
| 99 | |
| 89 // Set of registered local ids. | 100 // Set of registered local ids. |
| 90 std::set<uint16_t> ids_; | 101 std::set<uint16_t> ids_; |
| 91 | 102 |
| 92 // Maps from accelerator to the two ids registered for it. | 103 // Maps from accelerator to the two ids registered for it. |
| 93 std::map<ui::Accelerator, Ids> accelerator_to_ids_; | 104 std::map<ui::Accelerator, Ids> accelerator_to_ids_; |
| 94 | 105 |
| 95 DISALLOW_COPY_AND_ASSIGN(AcceleratorControllerRegistrar); | 106 DISALLOW_COPY_AND_ASSIGN(AcceleratorControllerRegistrar); |
| 96 }; | 107 }; |
| 97 | 108 |
| 98 } // namespace mus | 109 } // namespace mus |
| 99 } // namespace ash | 110 } // namespace ash |
| 100 | 111 |
| 101 #endif // ASH_MUS_ACCELERATORS_ACCELERATOR_CONTROLLER_REGISTRAR_H_ | 112 #endif // ASH_MUS_ACCELERATORS_ACCELERATOR_CONTROLLER_REGISTRAR_H_ |
| OLD | NEW |