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 #include "ash/mus/bridge/shell_port_mash.h" | 5 #include "ash/mus/bridge/shell_port_mash.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "ash/accelerators/accelerator_controller.h" | 9 #include "ash/accelerators/accelerator_controller.h" |
10 #include "ash/accelerators/accelerator_controller_delegate_aura.h" | 10 #include "ash/accelerators/accelerator_controller_delegate_aura.h" |
(...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
124 return window_manager_->config(); | 124 return window_manager_->config(); |
125 } | 125 } |
126 | 126 |
127 std::unique_ptr<display::TouchTransformSetter> | 127 std::unique_ptr<display::TouchTransformSetter> |
128 ShellPortMash::CreateTouchTransformDelegate() { | 128 ShellPortMash::CreateTouchTransformDelegate() { |
129 return base::MakeUnique<TouchTransformSetterMus>( | 129 return base::MakeUnique<TouchTransformSetterMus>( |
130 window_manager_->connector()); | 130 window_manager_->connector()); |
131 } | 131 } |
132 | 132 |
133 void ShellPortMash::LockCursor() { | 133 void ShellPortMash::LockCursor() { |
134 window_manager_->window_manager_client()->LockCursor(); | 134 // When we are running in mus, we need to keep track of state not just in the |
| 135 // window server, but also locally in ash because ash treats the cursor |
| 136 // manager as the canonical state for now. NativeCursorManagerAsh will keep |
| 137 // this state, while also forwarding it to the window manager for us. |
| 138 if (GetAshConfig() == Config::MUS) |
| 139 Shell::Get()->cursor_manager()->LockCursor(); |
| 140 else |
| 141 window_manager_->window_manager_client()->LockCursor(); |
135 } | 142 } |
136 | 143 |
137 void ShellPortMash::UnlockCursor() { | 144 void ShellPortMash::UnlockCursor() { |
138 window_manager_->window_manager_client()->UnlockCursor(); | 145 if (GetAshConfig() == Config::MUS) |
| 146 Shell::Get()->cursor_manager()->UnlockCursor(); |
| 147 else |
| 148 window_manager_->window_manager_client()->UnlockCursor(); |
139 } | 149 } |
140 | 150 |
141 void ShellPortMash::ShowCursor() { | 151 void ShellPortMash::ShowCursor() { |
142 window_manager_->window_manager_client()->SetCursorVisible(true); | 152 if (GetAshConfig() == Config::MUS) |
| 153 Shell::Get()->cursor_manager()->ShowCursor(); |
| 154 else |
| 155 window_manager_->window_manager_client()->SetCursorVisible(true); |
143 } | 156 } |
144 | 157 |
145 void ShellPortMash::HideCursor() { | 158 void ShellPortMash::HideCursor() { |
146 window_manager_->window_manager_client()->SetCursorVisible(false); | 159 if (GetAshConfig() == Config::MUS) |
| 160 Shell::Get()->cursor_manager()->HideCursor(); |
| 161 else |
| 162 window_manager_->window_manager_client()->SetCursorVisible(false); |
147 } | 163 } |
148 | 164 |
149 void ShellPortMash::SetCursorSize(ui::CursorSize cursor_size) { | 165 void ShellPortMash::SetCursorSize(ui::CursorSize cursor_size) { |
150 window_manager_->window_manager_client()->SetCursorSize(cursor_size); | 166 if (GetAshConfig() == Config::MUS) |
| 167 Shell::Get()->cursor_manager()->SetCursorSize(cursor_size); |
| 168 else |
| 169 window_manager_->window_manager_client()->SetCursorSize(cursor_size); |
151 } | 170 } |
152 | 171 |
153 void ShellPortMash::SetGlobalOverrideCursor( | 172 void ShellPortMash::SetGlobalOverrideCursor( |
154 base::Optional<ui::CursorData> cursor) { | 173 base::Optional<ui::CursorData> cursor) { |
| 174 DCHECK(mash_state_); |
155 window_manager_->window_manager_client()->SetGlobalOverrideCursor( | 175 window_manager_->window_manager_client()->SetGlobalOverrideCursor( |
156 std::move(cursor)); | 176 std::move(cursor)); |
157 } | 177 } |
158 | 178 |
159 bool ShellPortMash::IsMouseEventsEnabled() { | 179 bool ShellPortMash::IsMouseEventsEnabled() { |
160 // TODO: http://crbug.com/637853 | 180 // TODO: http://crbug.com/637853 |
161 NOTIMPLEMENTED(); | 181 NOTIMPLEMENTED(); |
162 return true; | 182 return true; |
163 } | 183 } |
164 | 184 |
(...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
372 mash_state_->accelerator_controller_registrar = | 392 mash_state_->accelerator_controller_registrar = |
373 base ::MakeUnique<AcceleratorControllerRegistrar>( | 393 base ::MakeUnique<AcceleratorControllerRegistrar>( |
374 window_manager_, accelerator_namespace_id); | 394 window_manager_, accelerator_namespace_id); |
375 return base::MakeUnique<AcceleratorController>( | 395 return base::MakeUnique<AcceleratorController>( |
376 mash_state_->accelerator_controller_delegate.get(), | 396 mash_state_->accelerator_controller_delegate.get(), |
377 mash_state_->accelerator_controller_registrar.get()); | 397 mash_state_->accelerator_controller_registrar.get()); |
378 } | 398 } |
379 | 399 |
380 } // namespace mus | 400 } // namespace mus |
381 } // namespace ash | 401 } // namespace ash |
OLD | NEW |