Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/scheduler/renderer/web_view_scheduler_impl.h" | 5 #include "components/scheduler/renderer/web_view_scheduler_impl.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "components/scheduler/renderer/renderer_scheduler_impl.h" | |
| 8 #include "components/scheduler/renderer/web_frame_scheduler_impl.h" | 9 #include "components/scheduler/renderer/web_frame_scheduler_impl.h" |
| 9 #include "third_party/WebKit/public/platform/WebFrameScheduler.h" | 10 #include "third_party/WebKit/public/platform/WebFrameScheduler.h" |
| 10 | 11 |
| 11 namespace scheduler { | 12 namespace scheduler { |
| 12 | 13 |
| 13 WebViewSchedulerImpl::WebViewSchedulerImpl( | 14 WebViewSchedulerImpl::WebViewSchedulerImpl( |
| 14 blink::WebView* web_view, | 15 blink::WebView* web_view, |
| 15 RendererSchedulerImpl* renderer_scheduler) | 16 RendererSchedulerImpl* renderer_scheduler, |
| 17 const char* tracing_category) | |
| 16 : web_view_(web_view), | 18 : web_view_(web_view), |
| 17 renderer_scheduler_(renderer_scheduler), | 19 renderer_scheduler_(renderer_scheduler), |
| 18 background_(false) {} | 20 tracing_category_(tracing_category), |
| 21 background_(false), | |
| 22 weak_factory_(this) { | |
| 23 pump_throttled_tasks_closure_.Reset(base::Bind( | |
|
Sami
2015/11/17 10:12:21
Doing this here is fine for now, but I wonder how
alex clarke (OOO till 29th)
2015/11/23 17:13:45
Yes we probably will add a helper.
| |
| 24 &WebViewSchedulerImpl::PumpThrottledTasks, weak_factory_.GetWeakPtr())); | |
| 25 } | |
| 19 | 26 |
| 20 WebViewSchedulerImpl::~WebViewSchedulerImpl() { | 27 WebViewSchedulerImpl::~WebViewSchedulerImpl() { |
| 21 // TODO(alexclarke): Find out why we can't rely on the web view outliving the | 28 // TODO(alexclarke): Find out why we can't rely on the web view outliving the |
| 22 // frame. | 29 // frame. |
| 23 for (WebFrameSchedulerImpl* frame_scheduler : frame_schedulers_) { | 30 for (WebFrameSchedulerImpl* frame_scheduler : frame_schedulers_) { |
| 24 frame_scheduler->DetachFromWebViewScheduler(); | 31 frame_scheduler->DetachFromWebViewScheduler(); |
| 25 } | 32 } |
| 26 } | 33 } |
| 27 | 34 |
| 28 void WebViewSchedulerImpl::setPageInBackground(bool background) { | 35 void WebViewSchedulerImpl::setPageInBackground(bool background) { |
| 36 if (background_ == background) | |
| 37 return; | |
| 38 | |
| 29 background_ = background; | 39 background_ = background; |
| 30 // TODO(alexclarke): Do something with this flag. | 40 |
| 41 for (WebFrameSchedulerImpl* frame_scheduler : frame_schedulers_) { | |
| 42 frame_scheduler->SetPageInBackground(background); | |
| 43 } | |
| 44 | |
| 45 if (background) { | |
| 46 SchedulePumpThrottledTasks(); | |
| 47 } else { | |
| 48 pump_throttled_tasks_closure_.Cancel(); | |
| 49 } | |
| 31 } | 50 } |
| 32 | 51 |
| 33 blink::WebPassOwnPtr<blink::WebFrameScheduler> | 52 blink::WebPassOwnPtr<blink::WebFrameScheduler> |
| 34 WebViewSchedulerImpl::createFrameScheduler() { | 53 WebViewSchedulerImpl::createFrameScheduler() { |
| 35 scoped_ptr<WebFrameSchedulerImpl> frame_scheduler( | 54 scoped_ptr<WebFrameSchedulerImpl> frame_scheduler( |
| 36 new WebFrameSchedulerImpl(renderer_scheduler_, this)); | 55 new WebFrameSchedulerImpl(renderer_scheduler_, this)); |
| 56 frame_scheduler->SetPageInBackground(background_); | |
| 37 frame_schedulers_.insert(frame_scheduler.get()); | 57 frame_schedulers_.insert(frame_scheduler.get()); |
| 38 return blink::adoptWebPtr(frame_scheduler.release()); | 58 return blink::adoptWebPtr(frame_scheduler.release()); |
| 39 } | 59 } |
| 40 | 60 |
| 41 void WebViewSchedulerImpl::Unregister(WebFrameSchedulerImpl* frame_scheduler) { | 61 void WebViewSchedulerImpl::Unregister(WebFrameSchedulerImpl* frame_scheduler) { |
| 42 DCHECK(frame_schedulers_.find(frame_scheduler) != frame_schedulers_.end()); | 62 DCHECK(frame_schedulers_.find(frame_scheduler) != frame_schedulers_.end()); |
| 43 frame_schedulers_.erase(frame_scheduler); | 63 frame_schedulers_.erase(frame_scheduler); |
| 44 } | 64 } |
| 45 | 65 |
| 66 void WebViewSchedulerImpl::PumpThrottledTasks() { | |
| 67 TRACE_EVENT0(tracing_category_, "WebViewSchedulerImpl::PumpThrottledTasks"); | |
| 68 DCHECK(background_); | |
| 69 for (WebFrameSchedulerImpl* frame_scheduler : frame_schedulers_) { | |
| 70 frame_scheduler->PumpBackgroundTasks(); | |
| 71 } | |
| 72 SchedulePumpThrottledTasks(); | |
|
Sami
2015/11/17 10:12:21
Will this ever stop ticking if there's no work to
alex clarke (OOO till 29th)
2015/11/23 17:13:45
I've changed it so it does.
| |
| 73 } | |
| 74 | |
| 75 /* static */ | |
| 76 double WebViewSchedulerImpl::DelayToNextRunTimeInSeconds( | |
| 77 double now_in_seconds) { | |
| 78 return ceilf(now_in_seconds + 0.2) - now_in_seconds; | |
|
Sami
2015/11/17 10:12:21
This probably deserves a comment and a named const
alex clarke (OOO till 29th)
2015/11/23 17:13:45
Yes and this also ticks once per second too.
| |
| 79 } | |
| 80 | |
| 81 void WebViewSchedulerImpl::SchedulePumpThrottledTasks() { | |
| 82 pump_throttled_tasks_closure_.Cancel(); | |
| 83 renderer_scheduler_->ControlTaskRunner()->PostDelayedTask( | |
| 84 FROM_HERE, pump_throttled_tasks_closure_.callback(), | |
| 85 base::TimeDelta::FromSecondsD(DelayToNextRunTimeInSeconds( | |
|
Sami
2015/11/17 10:12:21
Is there a way to do this calculation only using T
alex clarke (OOO till 29th)
2015/11/23 17:13:45
Done.
| |
| 86 renderer_scheduler_->MonotonicallyIncreasingTimeSeconds()))); | |
| 87 } | |
| 88 | |
| 46 } // namespace scheduler | 89 } // namespace scheduler |
| OLD | NEW |