blob: bc7d1ba2f9af1888cda7afa783947bc1ac439b2d [file] [log] [blame]
/*
* Copyright (C) 2013 University of Washington. All rights reserved.
* Copyright (C) 2014 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "config.h"
#include "UserInputBridge.h"
#include "EventHandler.h"
#include "FocusController.h"
#include "Frame.h"
#include "FrameLoadRequest.h"
#include "MainFrame.h"
#include "Page.h"
#include "PlatformKeyboardEvent.h"
#include "PlatformMouseEvent.h"
#include "PlatformWheelEvent.h"
#if ENABLE(WEB_REPLAY)
#include "ReplayController.h"
#include "SerializationMethods.h"
#include "WebReplayInputs.h"
#include <replay/InputCursor.h>
#endif
#define EARLY_RETURN_IF_SHOULD_IGNORE_INPUT \
do { \
if (inputSource == InputSource::User && m_state == UserInputBridge::State::Replaying) \
return true; \
} while (false)
namespace WebCore {
UserInputBridge::UserInputBridge(Page& page)
: m_page(page)
#if ENABLE(WEB_REPLAY)
, m_state(UserInputBridge::State::Open)
#endif
{
}
#if ENABLE(WEB_REPLAY)
InputCursor& UserInputBridge::activeCursor() const
{
return m_page.replayController().activeInputCursor();
}
#endif
#if ENABLE(CONTEXT_MENUS)
bool UserInputBridge::handleContextMenuEvent(const PlatformMouseEvent& mouseEvent, const Frame* frame, InputSource)
{
return frame->eventHandler().sendContextMenuEvent(mouseEvent);
}
#endif
bool UserInputBridge::handleMousePressEvent(const PlatformMouseEvent& mouseEvent, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing()) {
std::unique_ptr<PlatformMouseEvent> ownedEvent = std::make_unique<PlatformMouseEvent>(mouseEvent);
cursor.appendInput<HandleMousePress>(WTF::move(ownedEvent));
}
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.mainFrame().eventHandler().handleMousePressEvent(mouseEvent);
}
bool UserInputBridge::handleMouseReleaseEvent(const PlatformMouseEvent& mouseEvent, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing()) {
std::unique_ptr<PlatformMouseEvent> ownedEvent = std::make_unique<PlatformMouseEvent>(mouseEvent);
cursor.appendInput<HandleMouseRelease>(WTF::move(ownedEvent));
}
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.mainFrame().eventHandler().handleMouseReleaseEvent(mouseEvent);
}
bool UserInputBridge::handleMouseMoveEvent(const PlatformMouseEvent& mouseEvent, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing()) {
std::unique_ptr<PlatformMouseEvent> ownedEvent = std::make_unique<PlatformMouseEvent>(mouseEvent);
cursor.appendInput<HandleMouseMove>(WTF::move(ownedEvent), false);
}
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.mainFrame().eventHandler().mouseMoved(mouseEvent);
}
bool UserInputBridge::handleMouseMoveOnScrollbarEvent(const PlatformMouseEvent& mouseEvent, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing()) {
std::unique_ptr<PlatformMouseEvent> ownedEvent = std::make_unique<PlatformMouseEvent>(mouseEvent);
cursor.appendInput<HandleMouseMove>(WTF::move(ownedEvent), true);
}
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.mainFrame().eventHandler().passMouseMovedEventToScrollbars(mouseEvent);
}
bool UserInputBridge::handleMouseForceEvent(const PlatformMouseEvent& mouseEvent, InputSource)
{
return m_page.mainFrame().eventHandler().handleMouseForceEvent(mouseEvent);
}
bool UserInputBridge::handleKeyEvent(const PlatformKeyboardEvent& keyEvent, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing()) {
std::unique_ptr<PlatformKeyboardEvent> ownedEvent = std::make_unique<PlatformKeyboardEvent>(keyEvent);
cursor.appendInput<HandleKeyPress>(WTF::move(ownedEvent));
}
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.focusController().focusedOrMainFrame().eventHandler().keyEvent(keyEvent);
}
bool UserInputBridge::handleAccessKeyEvent(const PlatformKeyboardEvent& keyEvent, InputSource)
{
return m_page.focusController().focusedOrMainFrame().eventHandler().handleAccessKey(keyEvent);
}
bool UserInputBridge::handleWheelEvent(const PlatformWheelEvent& wheelEvent, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing()) {
std::unique_ptr<PlatformWheelEvent> ownedEvent = std::make_unique<PlatformWheelEvent>(wheelEvent);
cursor.appendInput<HandleWheelEvent>(WTF::move(ownedEvent));
}
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.mainFrame().eventHandler().handleWheelEvent(wheelEvent);
}
void UserInputBridge::focusSetActive(bool active, InputSource)
{
m_page.focusController().setActive(active);
}
void UserInputBridge::focusSetFocused(bool focused, InputSource)
{
m_page.focusController().setFocused(focused);
}
bool UserInputBridge::scrollRecursively(ScrollDirection direction, ScrollGranularity granularity, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing())
cursor.appendInput<ScrollPage>(direction, granularity);
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.focusController().focusedOrMainFrame().eventHandler().scrollRecursively(direction, granularity, nullptr);
}
bool UserInputBridge::logicalScrollRecursively(ScrollLogicalDirection direction, ScrollGranularity granularity, InputSource inputSource)
{
#if ENABLE(WEB_REPLAY)
EARLY_RETURN_IF_SHOULD_IGNORE_INPUT;
InputCursor& cursor = activeCursor();
if (cursor.isCapturing())
cursor.appendInput<LogicalScrollPage>(direction, granularity);
EventLoopInputExtent extent(cursor);
#else
UNUSED_PARAM(inputSource);
#endif
return m_page.focusController().focusedOrMainFrame().eventHandler().logicalScrollRecursively(direction, granularity, nullptr);
}
void UserInputBridge::loadRequest(const FrameLoadRequest& request, InputSource)
{
m_page.mainFrame().loader().load(request);
}
void UserInputBridge::reloadFrame(Frame* frame, bool endToEndReload, InputSource)
{
frame->loader().reload(endToEndReload);
}
void UserInputBridge::stopLoadingFrame(Frame* frame, InputSource)
{
frame->loader().stopForUserCancel();
}
bool UserInputBridge::tryClosePage(InputSource)
{
return m_page.mainFrame().loader().shouldClose();
}
} // namespace WebCore