summaryrefslogtreecommitdiff
path: root/Source/WebCore/page/PointerLockController.cpp
diff options
context:
space:
mode:
authorKonstantin Tokarev <annulen@yandex.ru>2016-08-25 19:20:41 +0300
committerKonstantin Tokarev <annulen@yandex.ru>2017-02-02 12:30:55 +0000
commit6882a04fb36642862b11efe514251d32070c3d65 (patch)
treeb7959826000b061fd5ccc7512035c7478742f7b0 /Source/WebCore/page/PointerLockController.cpp
parentab6df191029eeeb0b0f16f127d553265659f739e (diff)
downloadqtwebkit-6882a04fb36642862b11efe514251d32070c3d65.tar.gz
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/WebCore/page/PointerLockController.cpp')
-rw-r--r--Source/WebCore/page/PointerLockController.cpp52
1 files changed, 24 insertions, 28 deletions
diff --git a/Source/WebCore/page/PointerLockController.cpp b/Source/WebCore/page/PointerLockController.cpp
index 974b98da5..897a415d9 100644
--- a/Source/WebCore/page/PointerLockController.cpp
+++ b/Source/WebCore/page/PointerLockController.cpp
@@ -25,6 +25,8 @@
#include "config.h"
#include "PointerLockController.h"
+#if ENABLE(POINTER_LOCK)
+
#include "Chrome.h"
#include "ChromeClient.h"
#include "Element.h"
@@ -33,58 +35,52 @@
#include "PlatformMouseEvent.h"
#include "VoidCallback.h"
-#if ENABLE(POINTER_LOCK)
namespace WebCore {
-PointerLockController::PointerLockController(Page* page)
+PointerLockController::PointerLockController(Page& page)
: m_page(page)
+ , m_lockPending(false)
{
}
-PassOwnPtr<PointerLockController> PointerLockController::create(Page* page)
-{
- return adoptPtr(new PointerLockController(page));
-}
-
void PointerLockController::requestPointerLock(Element* target)
{
if (!target || !target->inDocument() || m_documentOfRemovedElementWhileWaitingForUnlock) {
- enqueueEvent(eventNames().webkitpointerlockerrorEvent, target);
+ enqueueEvent(eventNames().pointerlockerrorEvent, target);
return;
}
- if (target->document()->isSandboxed(SandboxPointerLock)) {
+ if (target->document().isSandboxed(SandboxPointerLock)) {
// FIXME: This message should be moved off the console once a solution to https://bugs.webkit.org/show_bug.cgi?id=103274 exists.
- target->document()->addConsoleMessage(SecurityMessageSource, ErrorMessageLevel, "Blocked pointer lock on an element because the element's frame is sandboxed and the 'allow-pointer-lock' permission is not set.");
- enqueueEvent(eventNames().webkitpointerlockerrorEvent, target);
+ target->document().addConsoleMessage(MessageSource::Security, MessageLevel::Error, ASCIILiteral("Blocked pointer lock on an element because the element's frame is sandboxed and the 'allow-pointer-lock' permission is not set."));
+ enqueueEvent(eventNames().pointerlockerrorEvent, target);
return;
}
if (m_element) {
- if (m_element->document() != target->document()) {
- enqueueEvent(eventNames().webkitpointerlockerrorEvent, target);
+ if (&m_element->document() != &target->document()) {
+ enqueueEvent(eventNames().pointerlockerrorEvent, target);
return;
}
- enqueueEvent(eventNames().webkitpointerlockchangeEvent, target);
+ enqueueEvent(eventNames().pointerlockchangeEvent, target);
m_element = target;
- } else if (m_page->chrome().client()->requestPointerLock()) {
+ } else if (m_page.chrome().client().requestPointerLock()) {
m_lockPending = true;
m_element = target;
- } else {
- enqueueEvent(eventNames().webkitpointerlockerrorEvent, target);
- }
+ } else
+ enqueueEvent(eventNames().pointerlockerrorEvent, target);
}
void PointerLockController::requestPointerUnlock()
{
- return m_page->chrome().client()->requestPointerUnlock();
+ return m_page.chrome().client().requestPointerUnlock();
}
void PointerLockController::elementRemoved(Element* element)
{
if (m_element == element) {
- m_documentOfRemovedElementWhileWaitingForUnlock = m_element->document();
+ m_documentOfRemovedElementWhileWaitingForUnlock = &m_element->document();
// Set element null immediately to block any future interaction with it
// including mouse events received before the unlock completes.
clearElement();
@@ -94,7 +90,7 @@ void PointerLockController::elementRemoved(Element* element)
void PointerLockController::documentDetached(Document* document)
{
- if (m_element && m_element->document() == document) {
+ if (m_element && &m_element->document() == document) {
clearElement();
requestPointerUnlock();
}
@@ -112,26 +108,26 @@ Element* PointerLockController::element() const
void PointerLockController::didAcquirePointerLock()
{
- enqueueEvent(eventNames().webkitpointerlockchangeEvent, m_element.get());
+ enqueueEvent(eventNames().pointerlockchangeEvent, m_element.get());
m_lockPending = false;
}
void PointerLockController::didNotAcquirePointerLock()
{
- enqueueEvent(eventNames().webkitpointerlockerrorEvent, m_element.get());
+ enqueueEvent(eventNames().pointerlockerrorEvent, m_element.get());
clearElement();
}
void PointerLockController::didLosePointerLock()
{
- enqueueEvent(eventNames().webkitpointerlockchangeEvent, m_element ? m_element->document() : m_documentOfRemovedElementWhileWaitingForUnlock.get());
+ enqueueEvent(eventNames().pointerlockchangeEvent, m_element ? &m_element->document() : m_documentOfRemovedElementWhileWaitingForUnlock.get());
clearElement();
- m_documentOfRemovedElementWhileWaitingForUnlock = 0;
+ m_documentOfRemovedElementWhileWaitingForUnlock = nullptr;
}
void PointerLockController::dispatchLockedMouseEvent(const PlatformMouseEvent& event, const AtomicString& eventType)
{
- if (!m_element || !m_element->document()->frame())
+ if (!m_element || !m_element->document().frame())
return;
m_element->dispatchMouseEvent(event, eventType, event.clickCount());
@@ -144,13 +140,13 @@ void PointerLockController::dispatchLockedMouseEvent(const PlatformMouseEvent& e
void PointerLockController::clearElement()
{
m_lockPending = false;
- m_element = 0;
+ m_element = nullptr;
}
void PointerLockController::enqueueEvent(const AtomicString& type, Element* element)
{
if (element)
- enqueueEvent(type, element->document());
+ enqueueEvent(type, &element->document());
}
void PointerLockController::enqueueEvent(const AtomicString& type, Document* document)