Chromium Code Reviews| 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 |