Index: Source/modules/battery/BatteryDispatcher.cpp |
diff --git a/Source/modules/battery/BatteryDispatcher.cpp b/Source/modules/battery/BatteryDispatcher.cpp |
index 515c49a7c6149a9c6c11f772f60d55bf1bede3f4..707f27e1e73370bbed8841b42421ca8331218e38 100644 |
--- a/Source/modules/battery/BatteryDispatcher.cpp |
+++ b/Source/modules/battery/BatteryDispatcher.cpp |
@@ -25,63 +25,17 @@ BatteryDispatcher::~BatteryDispatcher() |
{ |
} |
-void BatteryDispatcher::addClient(BatteryManager* batteryManager) |
-{ |
- addController(batteryManager); |
-} |
- |
-void BatteryDispatcher::removeClient(BatteryManager* batteryManager) |
-{ |
- removeController(batteryManager); |
-} |
- |
void BatteryDispatcher::updateBatteryStatus(const blink::WebBatteryStatus& batteryStatus) |
{ |
- RefPtr<BatteryStatus> oldStatus = m_batteryStatus; |
m_batteryStatus = BatteryStatus::create(batteryStatus.charging, batteryStatus.chargingTime, batteryStatus.dischargingTime, batteryStatus.level); |
- |
- if (oldStatus) { |
- if (m_batteryStatus->charging() != oldStatus->charging()) |
- didChangeBatteryStatus(EventTypeNames::chargingchange); |
- if (m_batteryStatus->charging() && m_batteryStatus->chargingTime() != oldStatus->chargingTime()) |
- didChangeBatteryStatus(EventTypeNames::chargingtimechange); |
- if (!m_batteryStatus->charging() && m_batteryStatus->dischargingTime() != oldStatus->dischargingTime()) |
- didChangeBatteryStatus(EventTypeNames::dischargingtimechange); |
- if (m_batteryStatus->level() != oldStatus->level()) |
- didChangeBatteryStatus(EventTypeNames::levelchange); |
- } else { |
- // There was no previous state. |
- didChangeBatteryStatus(EventTypeNames::chargingchange); |
- didChangeBatteryStatus(EventTypeNames::chargingtimechange); |
- didChangeBatteryStatus(EventTypeNames::dischargingtimechange); |
- didChangeBatteryStatus(EventTypeNames::levelchange); |
- } |
- |
+ notifyControllers(); |
} |
-const BatteryStatus* BatteryDispatcher::getLatestData() |
+BatteryStatus* BatteryDispatcher::latestData() |
{ |
return m_batteryStatus.get(); |
} |
-void BatteryDispatcher::didChangeBatteryStatus(const AtomicString& eventType) |
-{ |
- RefPtrWillBeRawPtr<Event> event = Event::create(eventType); |
- |
- { |
- TemporaryChange<bool> changeIsDispatching(m_isDispatching, true); |
- // Don't fire listeners removed or added during event dispatch. |
- size_t size = m_controllers.size(); |
- for (size_t i = 0; i < size; ++i) { |
- if (m_controllers[i]) |
- static_cast<BatteryManager*>(m_controllers[i])->didChangeBatteryStatus(event); |
- } |
- } |
- |
- if (m_needsPurge) |
- purgeControllers(); |
-} |
- |
void BatteryDispatcher::startListening() |
{ |
blink::Platform::current()->setBatteryStatusListener(this); |
@@ -90,6 +44,7 @@ void BatteryDispatcher::startListening() |
void BatteryDispatcher::stopListening() |
{ |
blink::Platform::current()->setBatteryStatusListener(0); |
+ m_batteryStatus.clear(); |
} |
} |