| Index: third_party/WebKit/Source/core/loader/NavigationScheduler.cpp
|
| diff --git a/third_party/WebKit/Source/core/loader/NavigationScheduler.cpp b/third_party/WebKit/Source/core/loader/NavigationScheduler.cpp
|
| index 440e46d4a0cc6ddb51934009f6eb554f1f7b6d1e..f997a42c346d04c810b45c95523981c5d1293a98 100644
|
| --- a/third_party/WebKit/Source/core/loader/NavigationScheduler.cpp
|
| +++ b/third_party/WebKit/Source/core/loader/NavigationScheduler.cpp
|
| @@ -420,7 +420,9 @@ void NavigationScheduler::startTimer()
|
| if (!m_redirect->shouldStartTimer(m_frame))
|
| return;
|
|
|
| - Platform::current()->currentThread()->scheduler()->loadingTaskRunner()->postDelayedTask(
|
| + WebScheduler* scheduler = Platform::current()->currentThread()->scheduler();
|
| + scheduler->navigationExpected();
|
| + scheduler->loadingTaskRunner()->postDelayedTask(
|
| FROM_HERE, m_navigateTaskFactory->cancelAndCreate(), m_redirect->delay() * 1000.0);
|
|
|
| InspectorInstrumentation::frameScheduledNavigation(m_frame, m_redirect->delay());
|
| @@ -428,8 +430,10 @@ void NavigationScheduler::startTimer()
|
|
|
| void NavigationScheduler::cancel()
|
| {
|
| - if (m_navigateTaskFactory->isPending())
|
| + if (m_navigateTaskFactory->isPending()) {
|
| + Platform::current()->currentThread()->scheduler()->navigationCanceled();
|
| InspectorInstrumentation::frameClearedScheduledNavigation(m_frame);
|
| + }
|
| m_navigateTaskFactory->cancel();
|
| m_redirect.clear();
|
| }
|
|
|