Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(94)

Side by Side Diff: chrome/browser/task_manager/providers/web_contents/subframe_task.cc

Issue 2437253002: Improve TDI render process naming in the task manager. (Closed)
Patch Set: typo Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 "chrome/browser/task_manager/providers/web_contents/subframe_task.h" 5 #include "chrome/browser/task_manager/providers/web_contents/subframe_task.h"
6 6
7 #include "base/strings/utf_string_conversions.h" 7 #include "base/strings/utf_string_conversions.h"
8 #include "chrome/grit/generated_resources.h" 8 #include "chrome/grit/generated_resources.h"
9 #include "content/public/browser/browser_context.h" 9 #include "content/public/browser/browser_context.h"
10 #include "content/public/browser/render_frame_host.h" 10 #include "content/public/browser/render_frame_host.h"
11 #include "content/public/browser/render_process_host.h" 11 #include "content/public/browser/render_process_host.h"
12 #include "content/public/browser/site_instance.h" 12 #include "content/public/browser/site_instance.h"
13 #include "content/public/browser/web_contents.h" 13 #include "content/public/browser/web_contents.h"
14 #include "extensions/browser/extension_registry.h" 14 #include "extensions/browser/extension_registry.h"
15 #include "extensions/common/constants.h" 15 #include "extensions/common/constants.h"
16 #include "extensions/common/extension.h" 16 #include "extensions/common/extension.h"
17 #include "extensions/common/extension_set.h" 17 #include "extensions/common/extension_set.h"
18 #include "ui/base/l10n/l10n_util.h" 18 #include "ui/base/l10n/l10n_util.h"
19 19
20 namespace task_manager { 20 namespace task_manager {
21 21
22 namespace {
23
24 base::string16 AdjustTitle(const content::SiteInstance* site_instance) {
25 DCHECK(site_instance);
26
27 // By default, subframe rows display the site, like this:
28 // "Subframe: http://example.com/"
29 const GURL& site_url = site_instance->GetSiteURL();
30 std::string name = site_url.spec();
31
32 // If |site_url| wraps a chrome extension id, we can display the extension
33 // name instead, which is more human-readable.
34 if (site_url.SchemeIs(extensions::kExtensionScheme)) {
35 const extensions::Extension* extension =
36 extensions::ExtensionRegistry::Get(site_instance->GetBrowserContext())
37 ->enabled_extensions()
38 .GetExtensionOrAppByURL(site_url);
39 if (extension)
40 name = extension->name();
41 }
42
43 int message_id = site_instance->GetBrowserContext()->IsOffTheRecord() ?
44 IDS_TASK_MANAGER_SUBFRAME_INCOGNITO_PREFIX :
45 IDS_TASK_MANAGER_SUBFRAME_PREFIX;
46 return l10n_util::GetStringFUTF16(message_id, base::UTF8ToUTF16(name));
47 }
48
49 } // namespace
50
51 SubframeTask::SubframeTask(content::RenderFrameHost* render_frame_host, 22 SubframeTask::SubframeTask(content::RenderFrameHost* render_frame_host,
52 content::WebContents* web_contents, 23 content::WebContents* web_contents,
53 RendererTask* main_task) 24 RendererTask* main_task)
54 : RendererTask(AdjustTitle(render_frame_host->GetSiteInstance()), 25 : RendererTask(base::string16(),
55 nullptr, 26 nullptr,
56 web_contents, 27 web_contents,
57 render_frame_host->GetProcess()), 28 render_frame_host->GetProcess()),
29 site_instance_(render_frame_host->GetSiteInstance()),
58 main_task_(main_task) { 30 main_task_(main_task) {
31 set_title(GetTitle());
59 // Note that we didn't get the RenderProcessHost from the WebContents, but 32 // Note that we didn't get the RenderProcessHost from the WebContents, but
60 // rather from the RenderFrameHost. Out-of-process iframes reside on 33 // rather from the RenderFrameHost. Out-of-process iframes reside on
61 // different processes than that of their main frame. 34 // different processes than that of their main frame.
62 } 35 }
63 36
64 SubframeTask::~SubframeTask() { 37 SubframeTask::~SubframeTask() {
65 } 38 }
66 39
67 void SubframeTask::UpdateTitle() { 40 void SubframeTask::UpdateTitle() {
ncarter (slow) 2016/10/24 22:55:31 Could you add a task_manager_browsertest that does
Avi (use Gerrit) 2016/10/26 00:41:39 Done.
68 // This will be called when the title changes on the WebContents's main frame, 41 set_title(GetTitle());
69 // but this Task represents other frames, so we don't care.
70 } 42 }
71 43
72 void SubframeTask::UpdateFavicon() { 44 void SubframeTask::UpdateFavicon() {
73 // This will be called when the favicon changes on the WebContents's main 45 // This will be called when the favicon changes on the WebContents's main
74 // frame, but this Task represents other frames, so we don't care. 46 // frame, but this Task represents other frames, so we don't care.
75 } 47 }
76 48
77 Task* SubframeTask::GetParentTask() const { 49 Task* SubframeTask::GetParentTask() const {
78 return main_task_; 50 return main_task_;
79 } 51 }
80 52
81 void SubframeTask::Activate() { 53 void SubframeTask::Activate() {
82 // Activate the root task. 54 // Activate the root task.
83 main_task_->Activate(); 55 main_task_->Activate();
84 } 56 }
85 57
58 base::string16 SubframeTask::GetTitle() {
59 DCHECK(site_instance_);
60
61 if (site_instance_->IsDefaultSubframeSiteInstance()) {
62 base::string16 main_task_title =
63 main_task_->GetTitleFromWebContents(main_task_->web_contents());
64 int message_id = site_instance_->GetBrowserContext()->IsOffTheRecord()
65 ? IDS_TASK_MANAGER_ISOLATED_INCOGNITO_SUBFRAMES_PREFIX
66 : IDS_TASK_MANAGER_ISOLATED_SUBFRAMES_PREFIX;
67 return l10n_util::GetStringFUTF16(message_id, main_task_title);
68 }
69
70 // By default, subframe rows display the site, like this:
71 // "Subframe: http://example.com/"
72 const GURL& site_url = site_instance_->GetSiteURL();
73 std::string name = site_url.spec();
74
75 // If |site_url| wraps a chrome extension id, we can display the extension
76 // name instead, which is more human-readable.
77 if (site_url.SchemeIs(extensions::kExtensionScheme)) {
78 const extensions::Extension* extension =
79 extensions::ExtensionRegistry::Get(site_instance_->GetBrowserContext())
80 ->enabled_extensions()
81 .GetExtensionOrAppByURL(site_url);
82 if (extension)
83 name = extension->name();
84 }
85
86 int message_id = site_instance_->GetBrowserContext()->IsOffTheRecord()
87 ? IDS_TASK_MANAGER_SUBFRAME_INCOGNITO_PREFIX
88 : IDS_TASK_MANAGER_SUBFRAME_PREFIX;
89 return l10n_util::GetStringFUTF16(message_id, base::UTF8ToUTF16(name));
90 }
91
86 } // namespace task_manager 92 } // namespace task_manager
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698