| 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 "services/ui/ws/window_manager_state.h" | 5 #include "services/ui/ws/window_manager_state.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/memory/weak_ptr.h" | 10 #include "base/memory/weak_ptr.h" |
| (...skipping 280 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 291 post_target_accelerator_.reset(); | 291 post_target_accelerator_.reset(); |
| 292 | 292 |
| 293 if (result == mojom::EventResult::UNHANDLED && post_target_accelerator) { | 293 if (result == mojom::EventResult::UNHANDLED && post_target_accelerator) { |
| 294 OnAccelerator(post_target_accelerator->id(), *details->event, | 294 OnAccelerator(post_target_accelerator->id(), *details->event, |
| 295 AcceleratorPhase::POST); | 295 AcceleratorPhase::POST); |
| 296 } | 296 } |
| 297 | 297 |
| 298 ProcessNextEventFromQueue(); | 298 ProcessNextEventFromQueue(); |
| 299 } | 299 } |
| 300 | 300 |
| 301 void WindowManagerState::OnAcceleratorAck(mojom::EventResult result) { | 301 void WindowManagerState::OnAcceleratorAck( |
| 302 mojom::EventResult result, |
| 303 const std::unordered_map<std::string, std::vector<uint8_t>>& properties) { |
| 302 if (!in_flight_event_details_ || | 304 if (!in_flight_event_details_ || |
| 303 in_flight_event_details_->phase != | 305 in_flight_event_details_->phase != |
| 304 EventDispatchPhase::PRE_TARGET_ACCELERATOR) { | 306 EventDispatchPhase::PRE_TARGET_ACCELERATOR) { |
| 305 // TODO(sad): The ack must have arrived after the timeout. We should do | 307 // TODO(sad): The ack must have arrived after the timeout. We should do |
| 306 // something here, and in OnEventAckTimeout(). | 308 // something here, and in OnEventAckTimeout(). |
| 307 return; | 309 return; |
| 308 } | 310 } |
| 309 | 311 |
| 310 std::unique_ptr<InFlightEventDetails> details = | 312 std::unique_ptr<InFlightEventDetails> details = |
| 311 std::move(in_flight_event_details_); | 313 std::move(in_flight_event_details_); |
| 312 | 314 |
| 313 if (result == mojom::EventResult::UNHANDLED) { | 315 if (result == mojom::EventResult::UNHANDLED) { |
| 316 DCHECK(details->event->IsKeyEvent()); |
| 317 if (!properties.empty()) |
| 318 details->event->AsKeyEvent()->SetProperties(properties); |
| 314 event_processing_display_id_ = details->display_id; | 319 event_processing_display_id_ = details->display_id; |
| 315 event_dispatcher_.ProcessEvent( | 320 event_dispatcher_.ProcessEvent( |
| 316 *details->event, EventDispatcher::AcceleratorMatchPhase::POST_ONLY); | 321 *details->event, EventDispatcher::AcceleratorMatchPhase::POST_ONLY); |
| 317 } else { | 322 } else { |
| 318 // We're not going to process the event any further, notify event observers. | 323 // We're not going to process the event any further, notify event observers. |
| 319 // We don't do this first to ensure we don't send an event twice to clients. | 324 // We don't do this first to ensure we don't send an event twice to clients. |
| 320 window_server()->SendToPointerWatchers(*details->event, user_id(), nullptr, | 325 window_server()->SendToPointerWatchers(*details->event, user_id(), nullptr, |
| 321 nullptr, details->display_id); | 326 nullptr, details->display_id); |
| 322 ProcessNextEventFromQueue(); | 327 ProcessNextEventFromQueue(); |
| 323 } | 328 } |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 374 NOTREACHED(); | 379 NOTREACHED(); |
| 375 return nullptr; | 380 return nullptr; |
| 376 } | 381 } |
| 377 | 382 |
| 378 void WindowManagerState::OnEventAckTimeout(ClientSpecificId client_id) { | 383 void WindowManagerState::OnEventAckTimeout(ClientSpecificId client_id) { |
| 379 WindowTree* hung_tree = window_server()->GetTreeWithId(client_id); | 384 WindowTree* hung_tree = window_server()->GetTreeWithId(client_id); |
| 380 if (hung_tree && !hung_tree->janky()) | 385 if (hung_tree && !hung_tree->janky()) |
| 381 window_tree_->ClientJankinessChanged(hung_tree); | 386 window_tree_->ClientJankinessChanged(hung_tree); |
| 382 if (in_flight_event_details_->phase == | 387 if (in_flight_event_details_->phase == |
| 383 EventDispatchPhase::PRE_TARGET_ACCELERATOR) { | 388 EventDispatchPhase::PRE_TARGET_ACCELERATOR) { |
| 384 OnAcceleratorAck(mojom::EventResult::UNHANDLED); | 389 OnAcceleratorAck(mojom::EventResult::UNHANDLED, KeyEvent::Properties()); |
| 385 } else { | 390 } else { |
| 386 OnEventAck( | 391 OnEventAck( |
| 387 in_flight_event_details_ ? in_flight_event_details_->tree : nullptr, | 392 in_flight_event_details_ ? in_flight_event_details_->tree : nullptr, |
| 388 mojom::EventResult::UNHANDLED); | 393 mojom::EventResult::UNHANDLED); |
| 389 } | 394 } |
| 390 } | 395 } |
| 391 | 396 |
| 392 void WindowManagerState::ProcessEventImpl(const ui::Event& event, | 397 void WindowManagerState::ProcessEventImpl(const ui::Event& event, |
| 393 int64_t display_id) { | 398 int64_t display_id) { |
| 394 // Debug accelerators are always checked and don't interfere with processing. | 399 // Debug accelerators are always checked and don't interfere with processing. |
| (...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 671 window->RemoveObserver(this); | 676 window->RemoveObserver(this); |
| 672 orphaned_window_manager_display_roots_.erase(iter); | 677 orphaned_window_manager_display_roots_.erase(iter); |
| 673 return; | 678 return; |
| 674 } | 679 } |
| 675 } | 680 } |
| 676 NOTREACHED(); | 681 NOTREACHED(); |
| 677 } | 682 } |
| 678 | 683 |
| 679 } // namespace ws | 684 } // namespace ws |
| 680 } // namespace ui | 685 } // namespace ui |
| OLD | NEW |