diff options
author | Konstantin Tokarev <annulen@yandex.ru> | 2016-08-25 19:20:41 +0300 |
---|---|---|
committer | Konstantin Tokarev <annulen@yandex.ru> | 2017-02-02 12:30:55 +0000 |
commit | 6882a04fb36642862b11efe514251d32070c3d65 (patch) | |
tree | b7959826000b061fd5ccc7512035c7478742f7b0 /Source/WebCore/page/PointerLockController.cpp | |
parent | ab6df191029eeeb0b0f16f127d553265659f739e (diff) | |
download | qtwebkit-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.cpp | 52 |
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) |