blob: f8c8cb32d868d4e59efef4385131d9d49aae9917 [file] [log] [blame]
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "core/frame/DOMTimerCoordinator.h"
#include "core/dom/ExecutionContext.h"
#include "core/frame/DOMTimer.h"
#include <algorithm>
namespace blink {
DOMTimerCoordinator::DOMTimerCoordinator(PassOwnPtr<WebTaskRunner> timerTaskRunner)
: m_circularSequentialID(0)
, m_timerNestingLevel(0)
, m_timerTaskRunner(timerTaskRunner)
{
}
int DOMTimerCoordinator::installNewTimeout(ExecutionContext* context, PassOwnPtrWillBeRawPtr<ScheduledAction> action, int timeout, bool singleShot)
{
// FIXME: DOMTimers depends heavily on ExecutionContext. Decouple them.
ASSERT(context->timers() == this);
int timeoutID = nextID();
TimeoutMap::AddResult result = m_timers.add(timeoutID, DOMTimer::create(context, action, timeout, singleShot, timeoutID));
ASSERT(result.isNewEntry);
DOMTimer* timer = result.storedValue->value.get();
timer->suspendIfNeeded();
return timeoutID;
}
void DOMTimerCoordinator::removeTimeoutByID(int timeoutID)
{
if (timeoutID <= 0)
return;
if (DOMTimer* removedTimer = m_timers.get(timeoutID))
removedTimer->disposeTimer();
m_timers.remove(timeoutID);
}
DEFINE_TRACE(DOMTimerCoordinator)
{
#if ENABLE(OILPAN)
visitor->trace(m_timers);
#endif
}
int DOMTimerCoordinator::nextID()
{
while (true) {
++m_circularSequentialID;
if (m_circularSequentialID <= 0)
m_circularSequentialID = 1;
if (!m_timers.contains(m_circularSequentialID))
return m_circularSequentialID;
}
}
void DOMTimerCoordinator::setTimerTaskRunner(PassOwnPtr<WebTaskRunner> timerTaskRunner)
{
m_timerTaskRunner = timerTaskRunner;
}
} // namespace blink