| Index: content/browser/renderer_host/input/synthetic_pointer_action.cc
|
| diff --git a/content/browser/renderer_host/input/synthetic_pointer_action.cc b/content/browser/renderer_host/input/synthetic_pointer_action.cc
|
| index 6353f342631d0cf7cb7ca49235e5e5311823921b..220a268ebd6558ec1afa929666c394103b6c76e7 100644
|
| --- a/content/browser/renderer_host/input/synthetic_pointer_action.cc
|
| +++ b/content/browser/renderer_host/input/synthetic_pointer_action.cc
|
| @@ -15,45 +15,61 @@ SyntheticPointerAction::SyntheticPointerAction(
|
| : params_(params) {}
|
|
|
| SyntheticPointerAction::SyntheticPointerAction(
|
| - const SyntheticPointerActionParams& params,
|
| - SyntheticPointer* synthetic_pointer)
|
| - : params_(params), synthetic_pointer_(synthetic_pointer) {}
|
| + const std::vector<SyntheticPointerActionParams>& param_list,
|
| + SyntheticPointer* synthetic_pointer,
|
| + IndexMap* index_map)
|
| + : param_list_(param_list),
|
| + synthetic_pointer_(synthetic_pointer),
|
| + index_map_(index_map) {}
|
|
|
| SyntheticPointerAction::~SyntheticPointerAction() {}
|
|
|
| SyntheticGesture::Result SyntheticPointerAction::ForwardInputEvents(
|
| const base::TimeTicks& timestamp,
|
| SyntheticGestureTarget* target) {
|
| - if (params_.gesture_source_type == SyntheticGestureParams::DEFAULT_INPUT)
|
| - params_.gesture_source_type =
|
| - target->GetDefaultSyntheticGestureSourceType();
|
| -
|
| - DCHECK_NE(params_.gesture_source_type, SyntheticGestureParams::DEFAULT_INPUT);
|
| -
|
| - ForwardTouchOrMouseInputEvents(timestamp, target);
|
| - return SyntheticGesture::GESTURE_FINISHED;
|
| + DCHECK(synthetic_pointer_);
|
| + return ForwardTouchOrMouseInputEvents(timestamp, target);
|
| }
|
|
|
| -void SyntheticPointerAction::ForwardTouchOrMouseInputEvents(
|
| +SyntheticGesture::Result SyntheticPointerAction::ForwardTouchOrMouseInputEvents(
|
| const base::TimeTicks& timestamp,
|
| SyntheticGestureTarget* target) {
|
| - switch (params_.pointer_action_type()) {
|
| - case SyntheticPointerActionParams::PointerActionType::PRESS:
|
| - synthetic_pointer_->Press(params_.position().x(), params_.position().y(),
|
| - target, timestamp);
|
| - break;
|
| - case SyntheticPointerActionParams::PointerActionType::MOVE:
|
| - synthetic_pointer_->Move(params_.index(), params_.position().x(),
|
| - params_.position().y(), target, timestamp);
|
| - break;
|
| - case SyntheticPointerActionParams::PointerActionType::RELEASE:
|
| - synthetic_pointer_->Release(params_.index(), target, timestamp);
|
| - break;
|
| - default:
|
| - NOTREACHED();
|
| - break;
|
| + for (auto iter = param_list_.begin(); iter != param_list_.end(); ++iter) {
|
| + SyntheticPointerActionParams params = *iter;
|
| + if (params.pointer_action_type() ==
|
| + SyntheticPointerActionParams::PointerActionType::FINISH)
|
| + return SyntheticGesture::POINTER_ACTION_FINISHED;
|
| + CHECK_GE(params.index(), 0);
|
| + CHECK_LT(params.index(), WebTouchEvent::touchesLengthCap);
|
| + switch (params.pointer_action_type()) {
|
| + case SyntheticPointerActionParams::PointerActionType::PRESS: {
|
| + int index = synthetic_pointer_->Press(
|
| + params.position().x(), params.position().y(), target, timestamp);
|
| + (*index_map_)[params.index()] = index;
|
| + break;
|
| + }
|
| + case SyntheticPointerActionParams::PointerActionType::MOVE:
|
| + CHECK_GE((*index_map_)[params.index()], 0);
|
| + CHECK_LT((*index_map_)[params.index()],
|
| + WebTouchEvent::touchesLengthCap);
|
| + synthetic_pointer_->Move((*index_map_)[params.index()],
|
| + params.position().x(), params.position().y(),
|
| + target, timestamp);
|
| + break;
|
| + case SyntheticPointerActionParams::PointerActionType::RELEASE:
|
| + CHECK_GE((*index_map_)[params.index()], 0);
|
| + CHECK_LT((*index_map_)[params.index()],
|
| + WebTouchEvent::touchesLengthCap);
|
| + synthetic_pointer_->Release((*index_map_)[params.index()], target,
|
| + timestamp);
|
| + break;
|
| + default:
|
| + NOTREACHED();
|
| + break;
|
| + }
|
| }
|
| synthetic_pointer_->DispatchEvent(target, timestamp);
|
| + return SyntheticGesture::POINTER_ACTION_PROCESSED;
|
| }
|
|
|
| } // namespace content
|
|
|