// Copyright (c) 2006-2008 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. #ifndef CHROME_BROWSER_TASK_MANAGER_RESOURCE_PROVIDERS_H_ #define CHROME_BROWSER_TASK_MANAGER_RESOURCE_PROVIDERS_H_ #include "base/basictypes.h" #include "chrome/browser/plugin_process_info.h" #include "chrome/browser/task_manager.h" #include "chrome/common/notification_observer.h" class PluginProcessHost; class WebContents; // These file contains the resource providers used in the task manager. class TaskManagerWebContentsResource : public TaskManager::Resource { public: explicit TaskManagerWebContentsResource(WebContents* web_contents); ~TaskManagerWebContentsResource(); // TaskManagerResource methods: std::wstring GetTitle() const; SkBitmap GetIcon() const; HANDLE GetProcess() const; TabContents* GetTabContents() const; // WebContents always provide the network usage. bool SupportNetworkUsage() const { return true; } void SetSupportNetworkUsage() { }; private: WebContents* web_contents_; HANDLE process_; int pid_; DISALLOW_COPY_AND_ASSIGN(TaskManagerWebContentsResource); }; class TaskManagerWebContentsResourceProvider : public TaskManager::ResourceProvider, public NotificationObserver { public: explicit TaskManagerWebContentsResourceProvider(TaskManager* task_manager); virtual ~TaskManagerWebContentsResourceProvider(); virtual TaskManager::Resource* GetResource(int origin_pid, int render_process_host_id, int routing_id); virtual void StartUpdating(); virtual void StopUpdating(); // NotificationObserver method: virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); private: void Add(WebContents* web_contents); void Remove(WebContents* web_contents); void AddToTaskManager(WebContents* web_contents); // Whether we are currently reporting to the task manager. Used to ignore // notifications sent after StopUpdating(). bool updating_; TaskManager* task_manager_; // Maps the actual resources (the WebContents) to the Task Manager // resources. std::map resources_; DISALLOW_COPY_AND_ASSIGN(TaskManagerWebContentsResourceProvider); }; class TaskManagerPluginProcessResource : public TaskManager::Resource { public: explicit TaskManagerPluginProcessResource(PluginProcessInfo plugin_proc); ~TaskManagerPluginProcessResource(); // TaskManagerResource methods: std::wstring GetTitle() const; SkBitmap GetIcon() const; HANDLE GetProcess() const; bool SupportNetworkUsage() const { return network_usage_support_; } void SetSupportNetworkUsage() { network_usage_support_ = true; } // Returns the pid of the plugin process. int process_id() const { return pid_; } private: PluginProcessInfo plugin_process_; int pid_; mutable std::wstring title_; bool network_usage_support_; // The icon painted for plugins. // TODO (jcampan): we should have plugin specific icons for well-known // plugins. static SkBitmap* default_icon_; DISALLOW_COPY_AND_ASSIGN(TaskManagerPluginProcessResource); }; class TaskManagerPluginProcessResourceProvider : public TaskManager::ResourceProvider, public NotificationObserver { public: explicit TaskManagerPluginProcessResourceProvider(TaskManager* task_manager); virtual ~TaskManagerPluginProcessResourceProvider(); virtual TaskManager::Resource* GetResource(int origin_pid, int render_process_host_id, int routing_id); virtual void StartUpdating(); virtual void StopUpdating(); // NotificationObserver method: virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); // Retrieves the current PluginProcessInfo (performed in the IO thread). virtual void RetrievePluginProcessInfo(); // Notifies the UI thread that the PluginProcessInfo have been retrieved. virtual void PluginProcessInfoRetreived(); // Whether we are currently reporting to the task manager. Used to ignore // notifications sent after StopUpdating(). bool updating_; // The list of PluginProcessInfo retrieved when starting the update. std::vector existing_plugin_process_info; private: void Add(PluginProcessInfo plugin_process_info); void Remove(PluginProcessInfo plugin_process_info); void AddToTaskManager(PluginProcessInfo plugin_process_info); TaskManager* task_manager_; MessageLoop* ui_loop_; // Maps the actual resources (the PluginProcessInfo) to the Task Manager // resources. std::map resources_; // Maps the pids to the resources (used for quick access to the resource on // byte read notifications). std::map pid_to_resources_; DISALLOW_COPY_AND_ASSIGN(TaskManagerPluginProcessResourceProvider); }; class TaskManagerBrowserProcessResource : public TaskManager::Resource { public: TaskManagerBrowserProcessResource(); ~TaskManagerBrowserProcessResource(); // TaskManagerResource methods: std::wstring GetTitle() const; SkBitmap GetIcon() const; HANDLE GetProcess() const; bool SupportNetworkUsage() const { return network_usage_support_; } void SetSupportNetworkUsage() { network_usage_support_ = true; } // Returns the pid of the browser process. int process_id() const { return pid_; } private: HANDLE process_; int pid_; bool network_usage_support_; mutable std::wstring title_; static SkBitmap* default_icon_; DISALLOW_COPY_AND_ASSIGN(TaskManagerBrowserProcessResource); }; class TaskManagerBrowserProcessResourceProvider : public TaskManager::ResourceProvider { public: explicit TaskManagerBrowserProcessResourceProvider( TaskManager* task_manager); virtual ~TaskManagerBrowserProcessResourceProvider(); virtual TaskManager::Resource* GetResource(int origin_pid, int render_process_host_id, int routing_id); virtual void StartUpdating(); virtual void StopUpdating(); // Whether we are currently reporting to the task manager. Used to ignore // notifications sent after StopUpdating(). bool updating_; private: void AddToTaskManager(PluginProcessInfo plugin_process_info); TaskManager* task_manager_; TaskManagerBrowserProcessResource resource_; DISALLOW_COPY_AND_ASSIGN(TaskManagerBrowserProcessResourceProvider); }; #endif // CHROME_BROWSER_TASK_MANAGER_RESOURCE_PROVIDERS_H_