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

Unified Diff: chrome/browser/task_manager/task_manager_extension_process_resource_provider.cc

Issue 15196003: Create task_manager namespace and wrap classes related to TaskManager with it. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 7 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/task_manager/task_manager_extension_process_resource_provider.cc
diff --git a/chrome/browser/task_manager/task_manager_extension_process_resource_provider.cc b/chrome/browser/task_manager/task_manager_extension_process_resource_provider.cc
deleted file mode 100644
index 907631d7ffa10755ff46965c05d3a650aa6348d7..0000000000000000000000000000000000000000
--- a/chrome/browser/task_manager/task_manager_extension_process_resource_provider.cc
+++ /dev/null
@@ -1,335 +0,0 @@
-// Copyright 2013 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "chrome/browser/task_manager/task_manager_extension_process_resource_provider.h"
-
-#include "base/string16.h"
-#include "base/utf_string_conversions.h"
-#include "chrome/browser/browser_process.h"
-#include "chrome/browser/devtools/devtools_window.h"
-#include "chrome/browser/extensions/extension_host.h"
-#include "chrome/browser/extensions/extension_process_manager.h"
-#include "chrome/browser/extensions/extension_system.h"
-#include "chrome/browser/profiles/profile.h"
-#include "chrome/browser/profiles/profile_manager.h"
-#include "chrome/browser/task_manager/task_manager_resource_util.h"
-#include "chrome/common/extensions/extension.h"
-#include "content/public/browser/render_process_host.h"
-#include "content/public/browser/render_view_host.h"
-#include "content/public/browser/site_instance.h"
-#include "content/public/browser/web_contents.h"
-#include "extensions/browser/view_type_utils.h"
-#include "grit/theme_resources.h"
-#include "ui/base/l10n/l10n_util.h"
-#include "ui/base/resource/resource_bundle.h"
-#include "ui/gfx/image/image_skia.h"
-
-using content::WebContents;
-using extensions::Extension;
-
-class TaskManagerExtensionProcessResource : public TaskManager::Resource {
- public:
- explicit TaskManagerExtensionProcessResource(
- content::RenderViewHost* render_view_host);
- virtual ~TaskManagerExtensionProcessResource();
-
- // TaskManager::Resource methods:
- virtual string16 GetTitle() const OVERRIDE;
- virtual string16 GetProfileName() const OVERRIDE;
- virtual gfx::ImageSkia GetIcon() const OVERRIDE;
- virtual base::ProcessHandle GetProcess() const OVERRIDE;
- virtual int GetUniqueChildProcessId() const OVERRIDE;
- virtual Type GetType() const OVERRIDE;
- virtual bool CanInspect() const OVERRIDE;
- virtual void Inspect() const OVERRIDE;
- virtual bool SupportNetworkUsage() const OVERRIDE;
- virtual void SetSupportNetworkUsage() OVERRIDE;
- virtual const extensions::Extension* GetExtension() const OVERRIDE;
-
- // Returns the pid of the extension process.
- int process_id() const { return pid_; }
-
- // Returns true if the associated extension has a background page.
- virtual bool IsBackground() const OVERRIDE;
-
- private:
- // The icon painted for the extension process.
- static gfx::ImageSkia* default_icon_;
-
- content::RenderViewHost* render_view_host_;
-
- // Cached data about the extension.
- base::ProcessHandle process_handle_;
- int pid_;
- int unique_process_id_;
- string16 title_;
-
- DISALLOW_COPY_AND_ASSIGN(TaskManagerExtensionProcessResource);
-};
-
-gfx::ImageSkia* TaskManagerExtensionProcessResource::default_icon_ = NULL;
-
-TaskManagerExtensionProcessResource::TaskManagerExtensionProcessResource(
- content::RenderViewHost* render_view_host)
- : render_view_host_(render_view_host) {
- if (!default_icon_) {
- ResourceBundle& rb = ResourceBundle::GetSharedInstance();
- default_icon_ = rb.GetImageSkiaNamed(IDR_PLUGINS_FAVICON);
- }
- process_handle_ = render_view_host_->GetProcess()->GetHandle();
- unique_process_id_ = render_view_host->GetProcess()->GetID();
- pid_ = base::GetProcId(process_handle_);
- string16 extension_name = UTF8ToUTF16(GetExtension()->name());
- DCHECK(!extension_name.empty());
-
- Profile* profile = Profile::FromBrowserContext(
- render_view_host->GetProcess()->GetBrowserContext());
- int message_id = TaskManagerResourceUtil::GetMessagePrefixID(
- GetExtension()->is_app(),
- true, // is_extension
- profile->IsOffTheRecord(),
- false, // is_prerender
- false, // is_instant_overlay
- IsBackground());
- title_ = l10n_util::GetStringFUTF16(message_id, extension_name);
-}
-
-TaskManagerExtensionProcessResource::~TaskManagerExtensionProcessResource() {
-}
-
-string16 TaskManagerExtensionProcessResource::GetTitle() const {
- return title_;
-}
-
-string16 TaskManagerExtensionProcessResource::GetProfileName() const {
- return TaskManagerResourceUtil::GetProfileNameFromInfoCache(
- Profile::FromBrowserContext(
- render_view_host_->GetProcess()->GetBrowserContext()));
-}
-
-gfx::ImageSkia TaskManagerExtensionProcessResource::GetIcon() const {
- return *default_icon_;
-}
-
-base::ProcessHandle TaskManagerExtensionProcessResource::GetProcess() const {
- return process_handle_;
-}
-
-int TaskManagerExtensionProcessResource::GetUniqueChildProcessId() const {
- return unique_process_id_;
-}
-
-TaskManager::Resource::Type
-TaskManagerExtensionProcessResource::GetType() const {
- return EXTENSION;
-}
-
-bool TaskManagerExtensionProcessResource::CanInspect() const {
- return true;
-}
-
-void TaskManagerExtensionProcessResource::Inspect() const {
- DevToolsWindow::OpenDevToolsWindow(render_view_host_);
-}
-
-bool TaskManagerExtensionProcessResource::SupportNetworkUsage() const {
- return true;
-}
-
-void TaskManagerExtensionProcessResource::SetSupportNetworkUsage() {
- NOTREACHED();
-}
-
-const Extension* TaskManagerExtensionProcessResource::GetExtension() const {
- Profile* profile = Profile::FromBrowserContext(
- render_view_host_->GetProcess()->GetBrowserContext());
- ExtensionProcessManager* process_manager =
- extensions::ExtensionSystem::Get(profile)->process_manager();
- return process_manager->GetExtensionForRenderViewHost(render_view_host_);
-}
-
-bool TaskManagerExtensionProcessResource::IsBackground() const {
- WebContents* web_contents =
- WebContents::FromRenderViewHost(render_view_host_);
- extensions::ViewType view_type = extensions::GetViewType(web_contents);
- return view_type == extensions::VIEW_TYPE_EXTENSION_BACKGROUND_PAGE;
-}
-
-////////////////////////////////////////////////////////////////////////////////
-// TaskManagerExtensionProcessResourceProvider class
-////////////////////////////////////////////////////////////////////////////////
-
-TaskManagerExtensionProcessResourceProvider::
- TaskManagerExtensionProcessResourceProvider(TaskManager* task_manager)
- : task_manager_(task_manager),
- updating_(false) {
-}
-
-TaskManagerExtensionProcessResourceProvider::
- ~TaskManagerExtensionProcessResourceProvider() {
-}
-
-TaskManager::Resource* TaskManagerExtensionProcessResourceProvider::GetResource(
- int origin_pid,
- int render_process_host_id,
- int routing_id) {
- // If an origin PID was specified, the request is from a plugin, not the
- // render view host process
- if (origin_pid)
- return NULL;
-
- for (ExtensionRenderViewHostMap::iterator i = resources_.begin();
- i != resources_.end(); i++) {
- if (i->first->GetSiteInstance()->GetProcess()->GetID() ==
- render_process_host_id &&
- i->first->GetRoutingID() == routing_id)
- return i->second;
- }
-
- // Can happen if the page went away while a network request was being
- // performed.
- return NULL;
-}
-
-void TaskManagerExtensionProcessResourceProvider::StartUpdating() {
- DCHECK(!updating_);
- updating_ = true;
-
- // Add all the existing extension views from all Profiles, including those
- // from incognito split mode.
- ProfileManager* profile_manager = g_browser_process->profile_manager();
- std::vector<Profile*> profiles(profile_manager->GetLoadedProfiles());
- size_t num_default_profiles = profiles.size();
- for (size_t i = 0; i < num_default_profiles; ++i) {
- if (profiles[i]->HasOffTheRecordProfile()) {
- profiles.push_back(profiles[i]->GetOffTheRecordProfile());
- }
- }
-
- for (size_t i = 0; i < profiles.size(); ++i) {
- ExtensionProcessManager* process_manager =
- extensions::ExtensionSystem::Get(profiles[i])->process_manager();
- if (process_manager) {
- const ExtensionProcessManager::ViewSet all_views =
- process_manager->GetAllViews();
- ExtensionProcessManager::ViewSet::const_iterator jt = all_views.begin();
- for (; jt != all_views.end(); ++jt) {
- content::RenderViewHost* rvh = *jt;
- // Don't add dead extension processes.
- if (!rvh->IsRenderViewLive())
- continue;
-
- AddToTaskManager(rvh);
- }
- }
- }
-
- // Register for notifications about extension process changes.
- registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_VIEW_REGISTERED,
- content::NotificationService::AllBrowserContextsAndSources());
- registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED,
- content::NotificationService::AllBrowserContextsAndSources());
- registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_VIEW_UNREGISTERED,
- content::NotificationService::AllBrowserContextsAndSources());
-}
-
-void TaskManagerExtensionProcessResourceProvider::StopUpdating() {
- DCHECK(updating_);
- updating_ = false;
-
- // Unregister for notifications about extension process changes.
- registrar_.Remove(
- this, chrome::NOTIFICATION_EXTENSION_VIEW_REGISTERED,
- content::NotificationService::AllBrowserContextsAndSources());
- registrar_.Remove(
- this, chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED,
- content::NotificationService::AllBrowserContextsAndSources());
- registrar_.Remove(
- this, chrome::NOTIFICATION_EXTENSION_VIEW_UNREGISTERED,
- content::NotificationService::AllBrowserContextsAndSources());
-
- // Delete all the resources.
- STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end());
-
- resources_.clear();
-}
-
-void TaskManagerExtensionProcessResourceProvider::Observe(
- int type,
- const content::NotificationSource& source,
- const content::NotificationDetails& details) {
- switch (type) {
- case chrome::NOTIFICATION_EXTENSION_VIEW_REGISTERED:
- AddToTaskManager(
- content::Details<content::RenderViewHost>(details).ptr());
- break;
- case chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED:
- RemoveFromTaskManager(
- content::Details<extensions::ExtensionHost>(details).ptr()->
- render_view_host());
- break;
- case chrome::NOTIFICATION_EXTENSION_VIEW_UNREGISTERED:
- RemoveFromTaskManager(
- content::Details<content::RenderViewHost>(details).ptr());
- break;
- default:
- NOTREACHED() << "Unexpected notification.";
- return;
- }
-}
-
-bool TaskManagerExtensionProcessResourceProvider::
- IsHandledByThisProvider(content::RenderViewHost* render_view_host) {
- WebContents* web_contents = WebContents::FromRenderViewHost(render_view_host);
- // Don't add WebContents that belong to a guest (those are handled by
- // TaskManagerGuestResourceProvider). Otherwise they will be added twice, and
- // in this case they will have the app's name as a title (due to the
- // TaskManagerExtensionProcessResource constructor).
- if (web_contents->GetRenderProcessHost()->IsGuest())
- return false;
- extensions::ViewType view_type = extensions::GetViewType(web_contents);
- // Don't add WebContents (those are handled by
- // TaskManagerTabContentsResourceProvider) or background contents (handled
- // by TaskManagerBackgroundResourceProvider).
-#if defined(USE_ASH)
- return (view_type != extensions::VIEW_TYPE_TAB_CONTENTS &&
- view_type != extensions::VIEW_TYPE_BACKGROUND_CONTENTS);
-#else
- return (view_type != extensions::VIEW_TYPE_TAB_CONTENTS &&
- view_type != extensions::VIEW_TYPE_BACKGROUND_CONTENTS &&
- view_type != extensions::VIEW_TYPE_PANEL);
-#endif // USE_ASH
-}
-
-void TaskManagerExtensionProcessResourceProvider::AddToTaskManager(
- content::RenderViewHost* render_view_host) {
- if (!IsHandledByThisProvider(render_view_host))
- return;
-
- TaskManagerExtensionProcessResource* resource =
- new TaskManagerExtensionProcessResource(render_view_host);
- DCHECK(resources_.find(render_view_host) == resources_.end());
- resources_[render_view_host] = resource;
- task_manager_->AddResource(resource);
-}
-
-void TaskManagerExtensionProcessResourceProvider::RemoveFromTaskManager(
- content::RenderViewHost* render_view_host) {
- if (!updating_)
- return;
- std::map<content::RenderViewHost*, TaskManagerExtensionProcessResource*>
- ::iterator iter = resources_.find(render_view_host);
- if (iter == resources_.end())
- return;
-
- // Remove the resource from the Task Manager.
- TaskManagerExtensionProcessResource* resource = iter->second;
- task_manager_->RemoveResource(resource);
-
- // Remove it from the provider.
- resources_.erase(iter);
-
- // Finally, delete the resource.
- delete resource;
-}

Powered by Google App Engine
This is Rietveld 408576698