| Index: Source/modules/device_orientation/DeviceMotionController.cpp
|
| diff --git a/Source/modules/device_orientation/DeviceMotionController.cpp b/Source/modules/device_orientation/DeviceMotionController.cpp
|
| index 02498d07240ac6daa7bd41d6b0409517ad44a915..b3c71fbdd4243f1c3670cab1b4eb537fc89162fe 100644
|
| --- a/Source/modules/device_orientation/DeviceMotionController.cpp
|
| +++ b/Source/modules/device_orientation/DeviceMotionController.cpp
|
| @@ -1,25 +1,29 @@
|
| /*
|
| - * Copyright 2010 Apple Inc. All rights reserved.
|
| - * Copyright (C) 2012 Samsung Electronics. All rights reserved.
|
| + * Copyright (C) 2013 Google 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:
|
| - * * Redistributions of source code must retain the above copyright
|
| - * notice, this list of conditions and the following disclaimer.
|
| - * * 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.
|
| + * modification, are permitted provided that the following conditions are
|
| + * met:
|
| *
|
| - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``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 OWNER 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
|
| + * * Redistributions of source code must retain the above copyright
|
| + * notice, this list of conditions and the following disclaimer.
|
| + * * 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.
|
| + * * Neither the name of Google Inc. nor the names of its
|
| + * contributors may be used to endorse or promote products derived from
|
| + * this software without specific prior written permission.
|
| + *
|
| + * 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
|
| + * OWNER 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.
|
| */
|
| @@ -28,8 +32,7 @@
|
| #include "modules/device_orientation/DeviceMotionController.h"
|
|
|
| #include "core/dom/Document.h"
|
| -#include "core/frame/DOMWindow.h"
|
| -#include "core/page/Page.h"
|
| +#include "modules/EventModules.h"
|
| #include "modules/device_orientation/DeviceMotionData.h"
|
| #include "modules/device_orientation/DeviceMotionDispatcher.h"
|
| #include "modules/device_orientation/DeviceMotionEvent.h"
|
| @@ -37,9 +40,7 @@
|
| namespace WebCore {
|
|
|
| DeviceMotionController::DeviceMotionController(Document& document)
|
| - : DeviceSensorEventController(document.page())
|
| - , DOMWindowLifecycleObserver(document.domWindow())
|
| - , m_document(document)
|
| + : DeviceSingleWindowEventController(document)
|
| {
|
| }
|
|
|
| @@ -48,11 +49,6 @@ DeviceMotionController::~DeviceMotionController()
|
| stopUpdating();
|
| }
|
|
|
| -void DeviceMotionController::didChangeDeviceMotion(DeviceMotionData* deviceMotionData)
|
| -{
|
| - dispatchDeviceEvent(DeviceMotionEvent::create(EventTypeNames::devicemotion, deviceMotionData));
|
| -}
|
| -
|
| const char* DeviceMotionController::supplementName()
|
| {
|
| return "DeviceMotionController";
|
| @@ -68,24 +64,24 @@ DeviceMotionController& DeviceMotionController::from(Document& document)
|
| return *controller;
|
| }
|
|
|
| -bool DeviceMotionController::hasLastData()
|
| +bool DeviceMotionController::isInvokeInitialUpdate()
|
| {
|
| return DeviceMotionDispatcher::instance().latestDeviceMotionData();
|
| }
|
|
|
| -PassRefPtrWillBeRawPtr<Event> DeviceMotionController::getLastEvent()
|
| +void DeviceMotionController::registerWithDispatcher()
|
| {
|
| - return DeviceMotionEvent::create(EventTypeNames::devicemotion, DeviceMotionDispatcher::instance().latestDeviceMotionData());
|
| + DeviceMotionDispatcher::instance().addController(this);
|
| }
|
|
|
| -void DeviceMotionController::registerWithDispatcher()
|
| +void DeviceMotionController::unregisterWithDispatcher()
|
| {
|
| - DeviceMotionDispatcher::instance().addDeviceMotionController(this);
|
| + DeviceMotionDispatcher::instance().removeController(this);
|
| }
|
|
|
| -void DeviceMotionController::unregisterWithDispatcher()
|
| +PassRefPtrWillBeRawPtr<Event> DeviceMotionController::getLastEvent()
|
| {
|
| - DeviceMotionDispatcher::instance().removeDeviceMotionController(this);
|
| + return DeviceMotionEvent::create(EventTypeNames::devicemotion, DeviceMotionDispatcher::instance().latestDeviceMotionData());
|
| }
|
|
|
| bool DeviceMotionController::isNullEvent(Event* event)
|
| @@ -94,35 +90,9 @@ bool DeviceMotionController::isNullEvent(Event* event)
|
| return !motionEvent->deviceMotionData()->canProvideEventData();
|
| }
|
|
|
| -Document* DeviceMotionController::document()
|
| -{
|
| - return &m_document;
|
| -}
|
| -
|
| -void DeviceMotionController::didAddEventListener(DOMWindow* window, const AtomicString& eventType)
|
| -{
|
| - if (eventType != EventTypeNames::devicemotion)
|
| - return;
|
| -
|
| - if (page() && page()->visibilityState() == PageVisibilityStateVisible)
|
| - startUpdating();
|
| -
|
| - m_hasEventListener = true;
|
| -}
|
| -
|
| -void DeviceMotionController::didRemoveEventListener(DOMWindow* window, const AtomicString& eventType)
|
| +const AtomicString& DeviceMotionController::getEventTypeName()
|
| {
|
| - if (eventType != EventTypeNames::devicemotion || window->hasEventListeners(EventTypeNames::devicemotion))
|
| - return;
|
| -
|
| - stopUpdating();
|
| - m_hasEventListener = false;
|
| -}
|
| -
|
| -void DeviceMotionController::didRemoveAllEventListeners(DOMWindow*)
|
| -{
|
| - stopUpdating();
|
| - m_hasEventListener = false;
|
| + return EventTypeNames::devicemotion;
|
| }
|
|
|
| } // namespace WebCore
|
|
|