| Index: Source/modules/battery/BatteryManager.cpp
|
| diff --git a/Source/modules/battery/BatteryManager.cpp b/Source/modules/battery/BatteryManager.cpp
|
| index 81114c592e416236594bcd520b4053f5049592a2..4e6d5a94fa6e329c96e74f6ed5f775a3f46a775a 100644
|
| --- a/Source/modules/battery/BatteryManager.cpp
|
| +++ b/Source/modules/battery/BatteryManager.cpp
|
| @@ -8,7 +8,6 @@
|
| #include "RuntimeEnabledFeatures.h"
|
| #include "modules/battery/BatteryDispatcher.h"
|
| #include "modules/battery/BatteryStatus.h"
|
| -#include <limits>
|
|
|
| namespace WebCore {
|
|
|
| @@ -21,11 +20,13 @@ PassRefPtrWillBeRawPtr<BatteryManager> BatteryManager::create(ExecutionContext*
|
|
|
| BatteryManager::~BatteryManager()
|
| {
|
| + stopUpdating();
|
| }
|
|
|
| BatteryManager::BatteryManager(ExecutionContext* context)
|
| : ActiveDOMObject(context)
|
| - , DeviceSensorEventController(toDocument(context)->page())
|
| + , DeviceEventControllerBase(toDocument(context)->page())
|
| + , m_batteryStatus(BatteryStatus::create())
|
| {
|
| m_hasEventListener = true;
|
| startUpdating();
|
| @@ -33,72 +34,63 @@ BatteryManager::BatteryManager(ExecutionContext* context)
|
|
|
| bool BatteryManager::charging()
|
| {
|
| - if (const BatteryStatus* lastData = BatteryDispatcher::instance().getLatestData())
|
| - return lastData->charging();
|
| -
|
| - return true;
|
| + return m_batteryStatus->charging();
|
| }
|
|
|
| double BatteryManager::chargingTime()
|
| {
|
| - if (const BatteryStatus* lastData = BatteryDispatcher::instance().getLatestData())
|
| - return lastData->chargingTime();
|
| -
|
| - return 0;
|
| + return m_batteryStatus->chargingTime();
|
| }
|
|
|
| double BatteryManager::dischargingTime()
|
| {
|
| - if (const BatteryStatus* lastData = BatteryDispatcher::instance().getLatestData())
|
| - return lastData->dischargingTime();
|
| -
|
| - return std::numeric_limits<double>::infinity();
|
| + return m_batteryStatus->dischargingTime();
|
| }
|
|
|
| double BatteryManager::level()
|
| {
|
| - if (const BatteryStatus* lastData = BatteryDispatcher::instance().getLatestData())
|
| - return lastData->level();
|
| -
|
| - return 1;
|
| + return m_batteryStatus->level();
|
| }
|
|
|
| -void BatteryManager::didChangeBatteryStatus(PassRefPtrWillBeRawPtr<Event> event)
|
| +void BatteryManager::didUpdateData()
|
| {
|
| ASSERT(RuntimeEnabledFeatures::batteryStatusEnabled());
|
|
|
| - dispatchEvent(event);
|
| -}
|
| + RefPtr<BatteryStatus> oldStatus = m_batteryStatus;
|
| + m_batteryStatus = BatteryDispatcher::instance().latestData();
|
|
|
| -void BatteryManager::registerWithDispatcher()
|
| -{
|
| - BatteryDispatcher::instance().addClient(this);
|
| -}
|
| + // BatteryDispatcher also holds a reference to m_batteryStatus.
|
| + ASSERT(m_batteryStatus->refCount() > 1);
|
|
|
| -void BatteryManager::unregisterWithDispatcher()
|
| -{
|
| - BatteryDispatcher::instance().removeClient(this);
|
| -}
|
| + Document* document = toDocument(executionContext());
|
| + if (document->activeDOMObjectsAreSuspended() || document->activeDOMObjectsAreStopped())
|
| + return;
|
|
|
| -bool BatteryManager::hasLastData()
|
| -{
|
| - return false;
|
| + ASSERT(oldStatus);
|
| +
|
| + if (m_batteryStatus->charging() != oldStatus->charging())
|
| + dispatchEvent(Event::create(EventTypeNames::chargingchange));
|
| + if (m_batteryStatus->chargingTime() != oldStatus->chargingTime())
|
| + dispatchEvent(Event::create(EventTypeNames::chargingtimechange));
|
| + if (m_batteryStatus->dischargingTime() != oldStatus->dischargingTime())
|
| + dispatchEvent(Event::create(EventTypeNames::dischargingtimechange));
|
| + if (m_batteryStatus->level() != oldStatus->level())
|
| + dispatchEvent(Event::create(EventTypeNames::levelchange));
|
| }
|
|
|
| -PassRefPtrWillBeRawPtr<Event> BatteryManager::getLastEvent()
|
| +void BatteryManager::registerWithDispatcher()
|
| {
|
| - // Events are dispached via BatteryManager::didChangeBatteryStatus()
|
| - return nullptr;
|
| + BatteryDispatcher::instance().addController(this);
|
| }
|
|
|
| -bool BatteryManager::isNullEvent(Event*)
|
| +void BatteryManager::unregisterWithDispatcher()
|
| {
|
| - return false;
|
| + BatteryDispatcher::instance().removeController(this);
|
| }
|
|
|
| -Document* BatteryManager::document()
|
| +bool BatteryManager::hasLastData()
|
| {
|
| - return toDocument(executionContext());
|
| + return BatteryDispatcher::instance().latestData();
|
| }
|
|
|
| void BatteryManager::suspend()
|
|
|