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 |