| Index: content/renderer/input/input_event_filter.cc
|
| diff --git a/content/renderer/input/input_event_filter.cc b/content/renderer/input/input_event_filter.cc
|
| index e9bd18ce6663e9e9a130212d230cb74aff34a86d..2be02a901b15eb1b411a375b1faf152cbf7026ff 100644
|
| --- a/content/renderer/input/input_event_filter.cc
|
| +++ b/content/renderer/input/input_event_filter.cc
|
| @@ -56,7 +56,6 @@ InputEventFilter::InputEventFilter(
|
| sender_(NULL),
|
| target_task_runner_(target_task_runner),
|
| input_handler_manager_(NULL),
|
| - current_overscroll_params_(NULL),
|
| renderer_scheduler_(NULL) {
|
| DCHECK(target_task_runner_.get());
|
| DCHECK(main_task_runner_->BelongsToCurrentThread());
|
| @@ -95,11 +94,6 @@ void InputEventFilter::UnregisterRoutingID(int routing_id) {
|
|
|
| void InputEventFilter::DidOverscroll(int routing_id,
|
| const DidOverscrollParams& params) {
|
| - if (current_overscroll_params_) {
|
| - current_overscroll_params_->reset(new DidOverscrollParams(params));
|
| - return;
|
| - }
|
| -
|
| SendMessage(std::unique_ptr<IPC::Message>(
|
| new InputHostMsg_DidOverscroll(routing_id, params)));
|
| }
|
| @@ -183,9 +177,7 @@ bool InputEventFilter::OnMessageReceived(const IPC::Message& message) {
|
| return true;
|
| }
|
|
|
| -InputEventFilter::~InputEventFilter() {
|
| - DCHECK(!current_overscroll_params_);
|
| -}
|
| +InputEventFilter::~InputEventFilter() {}
|
|
|
| void InputEventFilter::ForwardToHandler(const IPC::Message& message) {
|
| DCHECK(input_handler_manager_);
|
| @@ -210,22 +202,25 @@ void InputEventFilter::ForwardToHandler(const IPC::Message& message) {
|
| ui::WebInputEventTraits::Clone(*std::get<0>(params));
|
| ui::LatencyInfo latency_info = std::get<1>(params);
|
| InputEventDispatchType dispatch_type = std::get<2>(params);
|
| +
|
| DCHECK(event);
|
| DCHECK(dispatch_type == DISPATCH_TYPE_BLOCKING ||
|
| dispatch_type == DISPATCH_TYPE_NON_BLOCKING);
|
|
|
| - bool send_ack = dispatch_type == DISPATCH_TYPE_BLOCKING;
|
| -
|
| - // Intercept |DidOverscroll| notifications, bundling any triggered overscroll
|
| - // response with the input event ack.
|
| - std::unique_ptr<DidOverscrollParams> overscroll_params;
|
| - base::AutoReset<std::unique_ptr<DidOverscrollParams>*>
|
| - auto_reset_current_overscroll_params(
|
| - ¤t_overscroll_params_, send_ack ? &overscroll_params : NULL);
|
| -
|
| - InputEventAckState ack_state = input_handler_manager_->HandleInputEvent(
|
| - routing_id, event.get(), &latency_info);
|
| + input_handler_manager_->HandleInputEvent(
|
| + routing_id, std::move(event), latency_info,
|
| + base::Bind(&InputEventFilter::DidForwardToHandlerAndOverscroll, this,
|
| + routing_id, dispatch_type));
|
| +};
|
|
|
| +void InputEventFilter::DidForwardToHandlerAndOverscroll(
|
| + int routing_id,
|
| + InputEventDispatchType dispatch_type,
|
| + InputEventAckState ack_state,
|
| + ui::ScopedWebInputEvent event,
|
| + const ui::LatencyInfo& latency_info,
|
| + std::unique_ptr<DidOverscrollParams> overscroll_params) {
|
| + bool send_ack = dispatch_type == DISPATCH_TYPE_BLOCKING;
|
| uint32_t unique_touch_event_id =
|
| ui::WebInputEventTraits::GetUniqueTouchEventId(*event);
|
| WebInputEvent::Type type = event->type;
|
|
|