OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "chrome/browser/prerender/prerender_contents.h" | 5 #include "chrome/browser/prerender/prerender_contents.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <functional> | 8 #include <functional> |
9 #include <utility> | 9 #include <utility> |
10 | 10 |
11 #include "base/bind.h" | 11 #include "base/bind.h" |
12 #include "base/strings/utf_string_conversions.h" | 12 #include "base/strings/utf_string_conversions.h" |
13 #include "chrome/browser/chrome_notification_types.h" | 13 #include "chrome/browser/chrome_notification_types.h" |
14 #include "chrome/browser/history/history_tab_helper.h" | 14 #include "chrome/browser/history/history_tab_helper.h" |
15 #include "chrome/browser/prerender/prerender_field_trial.h" | 15 #include "chrome/browser/prerender/prerender_field_trial.h" |
16 #include "chrome/browser/prerender/prerender_final_status.h" | 16 #include "chrome/browser/prerender/prerender_final_status.h" |
17 #include "chrome/browser/prerender/prerender_handle.h" | 17 #include "chrome/browser/prerender/prerender_handle.h" |
18 #include "chrome/browser/prerender/prerender_manager.h" | 18 #include "chrome/browser/prerender/prerender_manager.h" |
19 #include "chrome/browser/prerender/prerender_manager_factory.h" | 19 #include "chrome/browser/prerender/prerender_manager_factory.h" |
20 #include "chrome/browser/prerender/prerender_resource_throttle.h" | 20 #include "chrome/browser/prerender/prerender_resource_throttle.h" |
21 #include "chrome/browser/profiles/profile.h" | 21 #include "chrome/browser/profiles/profile.h" |
22 #include "chrome/browser/task_management/web_contents_tags.h" | |
22 #include "chrome/browser/ui/browser.h" | 23 #include "chrome/browser/ui/browser.h" |
23 #include "chrome/browser/ui/tab_helpers.h" | 24 #include "chrome/browser/ui/tab_helpers.h" |
24 #include "chrome/browser/ui/web_contents_sizer.h" | 25 #include "chrome/browser/ui/web_contents_sizer.h" |
25 #include "chrome/common/prerender_messages.h" | 26 #include "chrome/common/prerender_messages.h" |
26 #include "chrome/common/render_messages.h" | 27 #include "chrome/common/render_messages.h" |
27 #include "chrome/common/url_constants.h" | 28 #include "chrome/common/url_constants.h" |
28 #include "components/history/core/browser/history_types.h" | 29 #include "components/history/core/browser/history_types.h" |
29 #include "content/public/browser/browser_child_process_host.h" | 30 #include "content/public/browser/browser_child_process_host.h" |
30 #include "content/public/browser/browser_thread.h" | 31 #include "content/public/browser/browser_thread.h" |
31 #include "content/public/browser/notification_service.h" | 32 #include "content/public/browser/notification_service.h" |
(...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
272 // control group. | 273 // control group. |
273 if (prerender_manager_->IsControlGroup()) | 274 if (prerender_manager_->IsControlGroup()) |
274 return; | 275 return; |
275 | 276 |
276 prerendering_has_started_ = true; | 277 prerendering_has_started_ = true; |
277 | 278 |
278 prerender_contents_.reset(CreateWebContents(session_storage_namespace)); | 279 prerender_contents_.reset(CreateWebContents(session_storage_namespace)); |
279 TabHelpers::AttachTabHelpers(prerender_contents_.get()); | 280 TabHelpers::AttachTabHelpers(prerender_contents_.get()); |
280 content::WebContentsObserver::Observe(prerender_contents_.get()); | 281 content::WebContentsObserver::Observe(prerender_contents_.get()); |
281 | 282 |
283 #if defined(ENABLE_TASK_MANAGER) | |
ncarter (slow)
2015/06/19 19:50:51
This is okay, but I wonder, would it be more elega
afakhry
2015/06/19 21:49:22
Unfortunately, it has to be done at the call site
ncarter (slow)
2015/06/20 04:34:47
What I was advocating, was to add the web_content_
gavinp
2015/06/22 18:40:15
I like Nick's suggestion. That way, simpler caller
| |
284 // Tag the prerender contents with the task-manager specific prerender tag, so | |
ncarter (slow)
2015/06/19 19:50:51
"task-manager" -> "task manager". Also below.
afakhry
2015/06/19 21:49:22
Done.
| |
285 // that it shows up in the task manager. | |
286 task_management::WebContentsTags::CreateForPrerenderContents( | |
287 prerender_contents_.get()); | |
288 #endif // defined(ENABLE_TASK_MANAGER) | |
289 | |
282 web_contents_delegate_.reset(new WebContentsDelegateImpl(this)); | 290 web_contents_delegate_.reset(new WebContentsDelegateImpl(this)); |
283 prerender_contents_.get()->SetDelegate(web_contents_delegate_.get()); | 291 prerender_contents_.get()->SetDelegate(web_contents_delegate_.get()); |
284 // Set the size of the prerender WebContents. | 292 // Set the size of the prerender WebContents. |
285 ResizeWebContents(prerender_contents_.get(), size_); | 293 ResizeWebContents(prerender_contents_.get(), size_); |
286 | 294 |
287 // TODO(davidben): This logic assumes each prerender has at most one | 295 // TODO(davidben): This logic assumes each prerender has at most one |
288 // route. https://crbug.com/440544 | 296 // route. https://crbug.com/440544 |
289 child_id_ = GetRenderViewHost()->GetProcess()->GetID(); | 297 child_id_ = GetRenderViewHost()->GetProcess()->GetID(); |
290 route_id_ = GetRenderViewHost()->GetRoutingID(); | 298 route_id_ = GetRenderViewHost()->GetRoutingID(); |
291 | 299 |
(...skipping 372 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
664 size_t private_bytes, shared_bytes; | 672 size_t private_bytes, shared_bytes; |
665 if (metrics->GetMemoryBytes(&private_bytes, &shared_bytes) && | 673 if (metrics->GetMemoryBytes(&private_bytes, &shared_bytes) && |
666 private_bytes > prerender_manager_->config().max_bytes) { | 674 private_bytes > prerender_manager_->config().max_bytes) { |
667 Destroy(FINAL_STATUS_MEMORY_LIMIT_EXCEEDED); | 675 Destroy(FINAL_STATUS_MEMORY_LIMIT_EXCEEDED); |
668 } | 676 } |
669 } | 677 } |
670 | 678 |
671 WebContents* PrerenderContents::ReleasePrerenderContents() { | 679 WebContents* PrerenderContents::ReleasePrerenderContents() { |
672 prerender_contents_->SetDelegate(NULL); | 680 prerender_contents_->SetDelegate(NULL); |
673 content::WebContentsObserver::Observe(NULL); | 681 content::WebContentsObserver::Observe(NULL); |
682 | |
683 #if defined(ENABLE_TASK_MANAGER) | |
684 // Here we have to clear the task-manager tag we added earlier to our | |
685 // WebContents since it's no longer a prerender content. | |
686 task_management::WebContentsTags::ClearTag(prerender_contents_.get()); | |
687 #endif // defined(ENABLE_TASK_MANAGER) | |
688 | |
674 return prerender_contents_.release(); | 689 return prerender_contents_.release(); |
675 } | 690 } |
676 | 691 |
677 RenderViewHost* PrerenderContents::GetRenderViewHostMutable() { | 692 RenderViewHost* PrerenderContents::GetRenderViewHostMutable() { |
678 return const_cast<RenderViewHost*>(GetRenderViewHost()); | 693 return const_cast<RenderViewHost*>(GetRenderViewHost()); |
679 } | 694 } |
680 | 695 |
681 const RenderViewHost* PrerenderContents::GetRenderViewHost() const { | 696 const RenderViewHost* PrerenderContents::GetRenderViewHost() const { |
682 if (!prerender_contents_.get()) | 697 if (!prerender_contents_.get()) |
683 return NULL; | 698 return NULL; |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
739 void PrerenderContents::AddResourceThrottle( | 754 void PrerenderContents::AddResourceThrottle( |
740 const base::WeakPtr<PrerenderResourceThrottle>& throttle) { | 755 const base::WeakPtr<PrerenderResourceThrottle>& throttle) { |
741 resource_throttles_.push_back(throttle); | 756 resource_throttles_.push_back(throttle); |
742 } | 757 } |
743 | 758 |
744 void PrerenderContents::AddNetworkBytes(int64 bytes) { | 759 void PrerenderContents::AddNetworkBytes(int64 bytes) { |
745 network_bytes_ += bytes; | 760 network_bytes_ += bytes; |
746 } | 761 } |
747 | 762 |
748 } // namespace prerender | 763 } // namespace prerender |
OLD | NEW |