OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/task_manager_resource_providers.h" | 5 #include "chrome/browser/task_manager/task_manager_resource_providers.h" |
6 | 6 |
7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
8 #include "base/file_version_info.h" | 8 #include "base/file_version_info.h" |
9 #include "base/i18n/rtl.h" | 9 #include "base/i18n/rtl.h" |
10 #include "base/process_util.h" | 10 #include "base/process_util.h" |
11 #include "base/stl_util-inl.h" | 11 #include "base/stl_util-inl.h" |
12 #include "base/string_util.h" | 12 #include "base/string_util.h" |
13 #include "base/threading/thread.h" | 13 #include "base/threading/thread.h" |
14 #include "base/utf_string_conversions.h" | 14 #include "base/utf_string_conversions.h" |
15 #include "build/build_config.h" | 15 #include "build/build_config.h" |
16 #include "chrome/app/chrome_command_ids.h" | 16 #include "chrome/app/chrome_command_ids.h" |
17 #include "chrome/browser/background/background_contents_service.h" | 17 #include "chrome/browser/background/background_contents_service.h" |
18 #include "chrome/browser/background/background_contents_service_factory.h" | 18 #include "chrome/browser/background/background_contents_service_factory.h" |
19 #include "chrome/browser/browser_process.h" | 19 #include "chrome/browser/browser_process.h" |
20 #include "chrome/browser/extensions/extension_host.h" | 20 #include "chrome/browser/extensions/extension_host.h" |
21 #include "chrome/browser/extensions/extension_process_manager.h" | 21 #include "chrome/browser/extensions/extension_process_manager.h" |
22 #include "chrome/browser/extensions/extension_service.h" | 22 #include "chrome/browser/extensions/extension_service.h" |
23 #include "chrome/browser/favicon/favicon_tab_helper.h" | 23 #include "chrome/browser/favicon/favicon_tab_helper.h" |
24 #include "chrome/browser/prerender/prerender_manager.h" | 24 #include "chrome/browser/prerender/prerender_manager.h" |
25 #include "chrome/browser/profiles/profile_manager.h" | 25 #include "chrome/browser/profiles/profile_manager.h" |
26 #include "chrome/browser/tab_contents/background_contents.h" | 26 #include "chrome/browser/tab_contents/background_contents.h" |
27 #include "chrome/browser/tab_contents/tab_util.h" | 27 #include "chrome/browser/tab_contents/tab_util.h" |
28 #include "chrome/browser/ui/browser_list.h" | 28 #include "chrome/browser/ui/browser_list.h" |
29 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" | 29 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" |
| 30 #include "chrome/common/chrome_notification_types.h" |
30 #include "chrome/common/chrome_switches.h" | 31 #include "chrome/common/chrome_switches.h" |
31 #include "chrome/common/extensions/extension.h" | 32 #include "chrome/common/extensions/extension.h" |
32 #include "chrome/common/render_messages.h" | 33 #include "chrome/common/render_messages.h" |
33 #include "content/browser/browser_child_process_host.h" | 34 #include "content/browser/browser_child_process_host.h" |
34 #include "content/browser/browser_thread.h" | 35 #include "content/browser/browser_thread.h" |
35 #include "content/browser/renderer_host/render_message_filter.h" | 36 #include "content/browser/renderer_host/render_message_filter.h" |
36 #include "content/browser/renderer_host/render_process_host.h" | 37 #include "content/browser/renderer_host/render_process_host.h" |
37 #include "content/browser/renderer_host/render_view_host.h" | 38 #include "content/browser/renderer_host/render_view_host.h" |
38 #include "content/browser/tab_contents/tab_contents.h" | 39 #include "content/browser/tab_contents/tab_contents.h" |
39 #include "content/common/notification_service.h" | 40 #include "content/common/notification_service.h" |
(...skipping 278 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
318 | 319 |
319 void TaskManagerTabContentsResourceProvider::StartUpdating() { | 320 void TaskManagerTabContentsResourceProvider::StartUpdating() { |
320 DCHECK(!updating_); | 321 DCHECK(!updating_); |
321 updating_ = true; | 322 updating_ = true; |
322 | 323 |
323 // Add all the existing TabContents. | 324 // Add all the existing TabContents. |
324 for (TabContentsIterator iterator; !iterator.done(); ++iterator) | 325 for (TabContentsIterator iterator; !iterator.done(); ++iterator) |
325 Add(*iterator); | 326 Add(*iterator); |
326 | 327 |
327 // Then we register for notifications to get new tabs. | 328 // Then we register for notifications to get new tabs. |
328 registrar_.Add(this, NotificationType::TAB_CONTENTS_CONNECTED, | 329 registrar_.Add(this, content::NOTIFICATION_TAB_CONTENTS_CONNECTED, |
329 NotificationService::AllSources()); | 330 NotificationService::AllSources()); |
330 registrar_.Add(this, NotificationType::TAB_CONTENTS_SWAPPED, | 331 registrar_.Add(this, content::NOTIFICATION_TAB_CONTENTS_SWAPPED, |
331 NotificationService::AllSources()); | 332 NotificationService::AllSources()); |
332 registrar_.Add(this, NotificationType::TAB_CONTENTS_DISCONNECTED, | 333 registrar_.Add(this, content::NOTIFICATION_TAB_CONTENTS_DISCONNECTED, |
333 NotificationService::AllSources()); | 334 NotificationService::AllSources()); |
334 // TAB_CONTENTS_DISCONNECTED should be enough to know when to remove a | 335 // TAB_CONTENTS_DISCONNECTED should be enough to know when to remove a |
335 // resource. This is an attempt at mitigating a crasher that seem to | 336 // resource. This is an attempt at mitigating a crasher that seem to |
336 // indicate a resource is still referencing a deleted TabContents | 337 // indicate a resource is still referencing a deleted TabContents |
337 // (http://crbug.com/7321). | 338 // (http://crbug.com/7321). |
338 registrar_.Add(this, NotificationType::TAB_CONTENTS_DESTROYED, | 339 registrar_.Add(this, content::NOTIFICATION_TAB_CONTENTS_DESTROYED, |
339 NotificationService::AllSources()); | 340 NotificationService::AllSources()); |
340 } | 341 } |
341 | 342 |
342 void TaskManagerTabContentsResourceProvider::StopUpdating() { | 343 void TaskManagerTabContentsResourceProvider::StopUpdating() { |
343 DCHECK(updating_); | 344 DCHECK(updating_); |
344 updating_ = false; | 345 updating_ = false; |
345 | 346 |
346 // Then we unregister for notifications to get new tabs. | 347 // Then we unregister for notifications to get new tabs. |
347 registrar_.Remove(this, NotificationType::TAB_CONTENTS_CONNECTED, | 348 registrar_.Remove(this, content::NOTIFICATION_TAB_CONTENTS_CONNECTED, |
348 NotificationService::AllSources()); | 349 NotificationService::AllSources()); |
349 registrar_.Remove(this, NotificationType::TAB_CONTENTS_SWAPPED, | 350 registrar_.Remove(this, content::NOTIFICATION_TAB_CONTENTS_SWAPPED, |
350 NotificationService::AllSources()); | 351 NotificationService::AllSources()); |
351 registrar_.Remove(this, NotificationType::TAB_CONTENTS_DISCONNECTED, | 352 registrar_.Remove(this, content::NOTIFICATION_TAB_CONTENTS_DISCONNECTED, |
352 NotificationService::AllSources()); | 353 NotificationService::AllSources()); |
353 registrar_.Remove(this, NotificationType::TAB_CONTENTS_DESTROYED, | 354 registrar_.Remove(this, content::NOTIFICATION_TAB_CONTENTS_DESTROYED, |
354 NotificationService::AllSources()); | 355 NotificationService::AllSources()); |
355 | 356 |
356 // Delete all the resources. | 357 // Delete all the resources. |
357 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); | 358 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); |
358 | 359 |
359 resources_.clear(); | 360 resources_.clear(); |
360 } | 361 } |
361 | 362 |
362 void TaskManagerTabContentsResourceProvider::AddToTaskManager( | 363 void TaskManagerTabContentsResourceProvider::AddToTaskManager( |
363 TabContentsWrapper* tab_contents) { | 364 TabContentsWrapper* tab_contents) { |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
406 | 407 |
407 // Remove the resource from the Task Manager. | 408 // Remove the resource from the Task Manager. |
408 TaskManagerTabContentsResource* resource = iter->second; | 409 TaskManagerTabContentsResource* resource = iter->second; |
409 task_manager_->RemoveResource(resource); | 410 task_manager_->RemoveResource(resource); |
410 // And from the provider. | 411 // And from the provider. |
411 resources_.erase(iter); | 412 resources_.erase(iter); |
412 // Finally, delete the resource. | 413 // Finally, delete the resource. |
413 delete resource; | 414 delete resource; |
414 } | 415 } |
415 | 416 |
416 void TaskManagerTabContentsResourceProvider::Observe(NotificationType type, | 417 void TaskManagerTabContentsResourceProvider::Observe(int type, |
417 const NotificationSource& source, | 418 const NotificationSource& source, |
418 const NotificationDetails& details) { | 419 const NotificationDetails& details) { |
419 TabContentsWrapper* tab_contents = | 420 TabContentsWrapper* tab_contents = |
420 TabContentsWrapper::GetCurrentWrapperForContents( | 421 TabContentsWrapper::GetCurrentWrapperForContents( |
421 Source<TabContents>(source).ptr()); | 422 Source<TabContents>(source).ptr()); |
422 // A background page does not have a TabContentsWrapper. | 423 // A background page does not have a TabContentsWrapper. |
423 if (!tab_contents) | 424 if (!tab_contents) |
424 return; | 425 return; |
425 switch (type.value) { | 426 switch (type) { |
426 case NotificationType::TAB_CONTENTS_CONNECTED: | 427 case content::NOTIFICATION_TAB_CONTENTS_CONNECTED: |
427 Add(tab_contents); | 428 Add(tab_contents); |
428 break; | 429 break; |
429 case NotificationType::TAB_CONTENTS_SWAPPED: | 430 case content::NOTIFICATION_TAB_CONTENTS_SWAPPED: |
430 Remove(tab_contents); | 431 Remove(tab_contents); |
431 Add(tab_contents); | 432 Add(tab_contents); |
432 break; | 433 break; |
433 case NotificationType::TAB_CONTENTS_DESTROYED: | 434 case content::NOTIFICATION_TAB_CONTENTS_DESTROYED: |
434 // If this DCHECK is triggered, it could explain http://crbug.com/7321 . | 435 // If this DCHECK is triggered, it could explain http://crbug.com/7321 . |
435 DCHECK(resources_.find(tab_contents) == | 436 DCHECK(resources_.find(tab_contents) == |
436 resources_.end()) << "TAB_CONTENTS_DESTROYED with no associated " | 437 resources_.end()) << "TAB_CONTENTS_DESTROYED with no associated " |
437 "TAB_CONTENTS_DISCONNECTED"; | 438 "TAB_CONTENTS_DISCONNECTED"; |
438 // Fall through. | 439 // Fall through. |
439 case NotificationType::TAB_CONTENTS_DISCONNECTED: | 440 case content::NOTIFICATION_TAB_CONTENTS_DISCONNECTED: |
440 Remove(tab_contents); | 441 Remove(tab_contents); |
441 break; | 442 break; |
442 default: | 443 default: |
443 NOTREACHED() << "Unexpected notification."; | 444 NOTREACHED() << "Unexpected notification."; |
444 return; | 445 return; |
445 } | 446 } |
446 } | 447 } |
447 | 448 |
448 //////////////////////////////////////////////////////////////////////////////// | 449 //////////////////////////////////////////////////////////////////////////////// |
449 // TaskManagerBackgroundContentsResource class | 450 // TaskManagerBackgroundContentsResource class |
(...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
558 const Extension* extension = extensions_service->GetExtensionById( | 559 const Extension* extension = extensions_service->GetExtensionById( |
559 UTF16ToUTF8(application_id), false); | 560 UTF16ToUTF8(application_id), false); |
560 if (extension) | 561 if (extension) |
561 application_name = UTF8ToUTF16(extension->name()); | 562 application_name = UTF8ToUTF16(extension->name()); |
562 } | 563 } |
563 Add(*iterator, application_name); | 564 Add(*iterator, application_name); |
564 } | 565 } |
565 } | 566 } |
566 | 567 |
567 // Then we register for notifications to get new BackgroundContents. | 568 // Then we register for notifications to get new BackgroundContents. |
568 registrar_.Add(this, NotificationType::BACKGROUND_CONTENTS_OPENED, | 569 registrar_.Add(this, chrome::NOTIFICATION_BACKGROUND_CONTENTS_OPENED, |
569 NotificationService::AllSources()); | 570 NotificationService::AllSources()); |
570 registrar_.Add(this, NotificationType::BACKGROUND_CONTENTS_NAVIGATED, | 571 registrar_.Add(this, chrome::NOTIFICATION_BACKGROUND_CONTENTS_NAVIGATED, |
571 NotificationService::AllSources()); | 572 NotificationService::AllSources()); |
572 registrar_.Add(this, NotificationType::BACKGROUND_CONTENTS_DELETED, | 573 registrar_.Add(this, chrome::NOTIFICATION_BACKGROUND_CONTENTS_DELETED, |
573 NotificationService::AllSources()); | 574 NotificationService::AllSources()); |
574 } | 575 } |
575 | 576 |
576 void TaskManagerBackgroundContentsResourceProvider::StopUpdating() { | 577 void TaskManagerBackgroundContentsResourceProvider::StopUpdating() { |
577 DCHECK(updating_); | 578 DCHECK(updating_); |
578 updating_ = false; | 579 updating_ = false; |
579 | 580 |
580 // Unregister for notifications | 581 // Unregister for notifications |
581 registrar_.Remove(this, NotificationType::BACKGROUND_CONTENTS_OPENED, | 582 registrar_.Remove(this, chrome::NOTIFICATION_BACKGROUND_CONTENTS_OPENED, |
582 NotificationService::AllSources()); | 583 NotificationService::AllSources()); |
583 registrar_.Remove(this, NotificationType::BACKGROUND_CONTENTS_NAVIGATED, | 584 registrar_.Remove(this, chrome::NOTIFICATION_BACKGROUND_CONTENTS_NAVIGATED, |
584 NotificationService::AllSources()); | 585 NotificationService::AllSources()); |
585 registrar_.Remove(this, NotificationType::BACKGROUND_CONTENTS_DELETED, | 586 registrar_.Remove(this, chrome::NOTIFICATION_BACKGROUND_CONTENTS_DELETED, |
586 NotificationService::AllSources()); | 587 NotificationService::AllSources()); |
587 | 588 |
588 // Delete all the resources. | 589 // Delete all the resources. |
589 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); | 590 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); |
590 | 591 |
591 resources_.clear(); | 592 resources_.clear(); |
592 } | 593 } |
593 | 594 |
594 void TaskManagerBackgroundContentsResourceProvider::AddToTaskManager( | 595 void TaskManagerBackgroundContentsResourceProvider::AddToTaskManager( |
595 BackgroundContents* background_contents, | 596 BackgroundContents* background_contents, |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
627 // Remove the resource from the Task Manager. | 628 // Remove the resource from the Task Manager. |
628 TaskManagerBackgroundContentsResource* resource = iter->second; | 629 TaskManagerBackgroundContentsResource* resource = iter->second; |
629 task_manager_->RemoveResource(resource); | 630 task_manager_->RemoveResource(resource); |
630 // And from the provider. | 631 // And from the provider. |
631 resources_.erase(iter); | 632 resources_.erase(iter); |
632 // Finally, delete the resource. | 633 // Finally, delete the resource. |
633 delete resource; | 634 delete resource; |
634 } | 635 } |
635 | 636 |
636 void TaskManagerBackgroundContentsResourceProvider::Observe( | 637 void TaskManagerBackgroundContentsResourceProvider::Observe( |
637 NotificationType type, | 638 int type, |
638 const NotificationSource& source, | 639 const NotificationSource& source, |
639 const NotificationDetails& details) { | 640 const NotificationDetails& details) { |
640 switch (type.value) { | 641 switch (type) { |
641 case NotificationType::BACKGROUND_CONTENTS_OPENED: { | 642 case chrome::NOTIFICATION_BACKGROUND_CONTENTS_OPENED: { |
642 // Get the name from the parent application. If no parent application is | 643 // Get the name from the parent application. If no parent application is |
643 // found, just pass an empty string - BackgroundContentsResource::GetTitle | 644 // found, just pass an empty string - BackgroundContentsResource::GetTitle |
644 // will display the URL instead in this case. This should never happen | 645 // will display the URL instead in this case. This should never happen |
645 // except in rare cases when an extension is being unloaded or chrome is | 646 // except in rare cases when an extension is being unloaded or chrome is |
646 // exiting while the task manager is displayed. | 647 // exiting while the task manager is displayed. |
647 string16 application_name; | 648 string16 application_name; |
648 ExtensionService* service = | 649 ExtensionService* service = |
649 Source<Profile>(source)->GetExtensionService(); | 650 Source<Profile>(source)->GetExtensionService(); |
650 if (service) { | 651 if (service) { |
651 std::string application_id = UTF16ToUTF8( | 652 std::string application_id = UTF16ToUTF8( |
652 Details<BackgroundContentsOpenedDetails>(details)->application_id); | 653 Details<BackgroundContentsOpenedDetails>(details)->application_id); |
653 const Extension* extension = | 654 const Extension* extension = |
654 service->GetExtensionById(application_id, false); | 655 service->GetExtensionById(application_id, false); |
655 // Extension can be NULL when running unit tests. | 656 // Extension can be NULL when running unit tests. |
656 if (extension) | 657 if (extension) |
657 application_name = UTF8ToUTF16(extension->name()); | 658 application_name = UTF8ToUTF16(extension->name()); |
658 } | 659 } |
659 Add(Details<BackgroundContentsOpenedDetails>(details)->contents, | 660 Add(Details<BackgroundContentsOpenedDetails>(details)->contents, |
660 application_name); | 661 application_name); |
661 // Opening a new BackgroundContents needs to force the display to refresh | 662 // Opening a new BackgroundContents needs to force the display to refresh |
662 // (applications may now be considered "background" that weren't before). | 663 // (applications may now be considered "background" that weren't before). |
663 task_manager_->ModelChanged(); | 664 task_manager_->ModelChanged(); |
664 break; | 665 break; |
665 } | 666 } |
666 case NotificationType::BACKGROUND_CONTENTS_NAVIGATED: { | 667 case chrome::NOTIFICATION_BACKGROUND_CONTENTS_NAVIGATED: { |
667 BackgroundContents* contents = Details<BackgroundContents>(details).ptr(); | 668 BackgroundContents* contents = Details<BackgroundContents>(details).ptr(); |
668 // Should never get a NAVIGATED before OPENED. | 669 // Should never get a NAVIGATED before OPENED. |
669 DCHECK(resources_.find(contents) != resources_.end()); | 670 DCHECK(resources_.find(contents) != resources_.end()); |
670 // Preserve the application name. | 671 // Preserve the application name. |
671 string16 application_name( | 672 string16 application_name( |
672 resources_.find(contents)->second->application_name()); | 673 resources_.find(contents)->second->application_name()); |
673 Remove(contents); | 674 Remove(contents); |
674 Add(contents, application_name); | 675 Add(contents, application_name); |
675 break; | 676 break; |
676 } | 677 } |
677 case NotificationType::BACKGROUND_CONTENTS_DELETED: | 678 case chrome::NOTIFICATION_BACKGROUND_CONTENTS_DELETED: |
678 Remove(Details<BackgroundContents>(details).ptr()); | 679 Remove(Details<BackgroundContents>(details).ptr()); |
679 // Closing a BackgroundContents needs to force the display to refresh | 680 // Closing a BackgroundContents needs to force the display to refresh |
680 // (applications may now be considered "foreground" that weren't before). | 681 // (applications may now be considered "foreground" that weren't before). |
681 task_manager_->ModelChanged(); | 682 task_manager_->ModelChanged(); |
682 break; | 683 break; |
683 default: | 684 default: |
684 NOTREACHED() << "Unexpected notification."; | 685 NOTREACHED() << "Unexpected notification."; |
685 return; | 686 return; |
686 } | 687 } |
687 } | 688 } |
(...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
842 return iter->second; | 843 return iter->second; |
843 else | 844 else |
844 return NULL; | 845 return NULL; |
845 } | 846 } |
846 | 847 |
847 void TaskManagerChildProcessResourceProvider::StartUpdating() { | 848 void TaskManagerChildProcessResourceProvider::StartUpdating() { |
848 DCHECK(!updating_); | 849 DCHECK(!updating_); |
849 updating_ = true; | 850 updating_ = true; |
850 | 851 |
851 // Register for notifications to get new child processes. | 852 // Register for notifications to get new child processes. |
852 registrar_.Add(this, NotificationType::CHILD_PROCESS_HOST_CONNECTED, | 853 registrar_.Add(this, content::NOTIFICATION_CHILD_PROCESS_HOST_CONNECTED, |
853 NotificationService::AllSources()); | 854 NotificationService::AllSources()); |
854 registrar_.Add(this, NotificationType::CHILD_PROCESS_HOST_DISCONNECTED, | 855 registrar_.Add(this, content::NOTIFICATION_CHILD_PROCESS_HOST_DISCONNECTED, |
855 NotificationService::AllSources()); | 856 NotificationService::AllSources()); |
856 | 857 |
857 // Get the existing child processes. | 858 // Get the existing child processes. |
858 BrowserThread::PostTask( | 859 BrowserThread::PostTask( |
859 BrowserThread::IO, FROM_HERE, | 860 BrowserThread::IO, FROM_HERE, |
860 NewRunnableMethod( | 861 NewRunnableMethod( |
861 this, | 862 this, |
862 &TaskManagerChildProcessResourceProvider::RetrieveChildProcessInfo)); | 863 &TaskManagerChildProcessResourceProvider::RetrieveChildProcessInfo)); |
863 } | 864 } |
864 | 865 |
865 void TaskManagerChildProcessResourceProvider::StopUpdating() { | 866 void TaskManagerChildProcessResourceProvider::StopUpdating() { |
866 DCHECK(updating_); | 867 DCHECK(updating_); |
867 updating_ = false; | 868 updating_ = false; |
868 | 869 |
869 // Unregister for notifications to get new plugin processes. | 870 // Unregister for notifications to get new plugin processes. |
870 registrar_.Remove(this, NotificationType::CHILD_PROCESS_HOST_CONNECTED, | 871 registrar_.Remove(this, content::NOTIFICATION_CHILD_PROCESS_HOST_CONNECTED, |
871 NotificationService::AllSources()); | 872 NotificationService::AllSources()); |
872 registrar_.Remove(this, | 873 registrar_.Remove(this, |
873 NotificationType::CHILD_PROCESS_HOST_DISCONNECTED, | 874 content::NOTIFICATION_CHILD_PROCESS_HOST_DISCONNECTED, |
874 NotificationService::AllSources()); | 875 NotificationService::AllSources()); |
875 | 876 |
876 // Delete all the resources. | 877 // Delete all the resources. |
877 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); | 878 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); |
878 | 879 |
879 resources_.clear(); | 880 resources_.clear(); |
880 pid_to_resources_.clear(); | 881 pid_to_resources_.clear(); |
881 existing_child_process_info_.clear(); | 882 existing_child_process_info_.clear(); |
882 } | 883 } |
883 | 884 |
884 void TaskManagerChildProcessResourceProvider::Observe( | 885 void TaskManagerChildProcessResourceProvider::Observe( |
885 NotificationType type, | 886 int type, |
886 const NotificationSource& source, | 887 const NotificationSource& source, |
887 const NotificationDetails& details) { | 888 const NotificationDetails& details) { |
888 switch (type.value) { | 889 switch (type) { |
889 case NotificationType::CHILD_PROCESS_HOST_CONNECTED: | 890 case content::NOTIFICATION_CHILD_PROCESS_HOST_CONNECTED: |
890 Add(*Details<ChildProcessInfo>(details).ptr()); | 891 Add(*Details<ChildProcessInfo>(details).ptr()); |
891 break; | 892 break; |
892 case NotificationType::CHILD_PROCESS_HOST_DISCONNECTED: | 893 case content::NOTIFICATION_CHILD_PROCESS_HOST_DISCONNECTED: |
893 Remove(*Details<ChildProcessInfo>(details).ptr()); | 894 Remove(*Details<ChildProcessInfo>(details).ptr()); |
894 break; | 895 break; |
895 default: | 896 default: |
896 NOTREACHED() << "Unexpected notification."; | 897 NOTREACHED() << "Unexpected notification."; |
897 return; | 898 return; |
898 } | 899 } |
899 } | 900 } |
900 | 901 |
901 void TaskManagerChildProcessResourceProvider::Add( | 902 void TaskManagerChildProcessResourceProvider::Add( |
902 const ChildProcessInfo& child_process_info) { | 903 const ChildProcessInfo& child_process_info) { |
(...skipping 182 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1085 profiles[i]->GetOffTheRecordProfile()->GetExtensionProcessManager(); | 1086 profiles[i]->GetOffTheRecordProfile()->GetExtensionProcessManager(); |
1086 if (process_manager) { | 1087 if (process_manager) { |
1087 ExtensionProcessManager::const_iterator jt; | 1088 ExtensionProcessManager::const_iterator jt; |
1088 for (jt = process_manager->begin(); jt != process_manager->end(); ++jt) | 1089 for (jt = process_manager->begin(); jt != process_manager->end(); ++jt) |
1089 AddToTaskManager(*jt); | 1090 AddToTaskManager(*jt); |
1090 } | 1091 } |
1091 } | 1092 } |
1092 } | 1093 } |
1093 | 1094 |
1094 // Register for notifications about extension process changes. | 1095 // Register for notifications about extension process changes. |
1095 registrar_.Add(this, NotificationType::EXTENSION_PROCESS_CREATED, | 1096 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_PROCESS_CREATED, |
1096 NotificationService::AllSources()); | 1097 NotificationService::AllSources()); |
1097 registrar_.Add(this, NotificationType::EXTENSION_PROCESS_TERMINATED, | 1098 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED, |
1098 NotificationService::AllSources()); | 1099 NotificationService::AllSources()); |
1099 registrar_.Add(this, NotificationType::EXTENSION_HOST_DESTROYED, | 1100 registrar_.Add(this, chrome::NOTIFICATION_EXTENSION_HOST_DESTROYED, |
1100 NotificationService::AllSources()); | 1101 NotificationService::AllSources()); |
1101 } | 1102 } |
1102 | 1103 |
1103 void TaskManagerExtensionProcessResourceProvider::StopUpdating() { | 1104 void TaskManagerExtensionProcessResourceProvider::StopUpdating() { |
1104 DCHECK(updating_); | 1105 DCHECK(updating_); |
1105 updating_ = false; | 1106 updating_ = false; |
1106 | 1107 |
1107 // Unregister for notifications about extension process changes. | 1108 // Unregister for notifications about extension process changes. |
1108 registrar_.Remove(this, NotificationType::EXTENSION_PROCESS_CREATED, | 1109 registrar_.Remove(this, chrome::NOTIFICATION_EXTENSION_PROCESS_CREATED, |
1109 NotificationService::AllSources()); | 1110 NotificationService::AllSources()); |
1110 registrar_.Remove(this, NotificationType::EXTENSION_PROCESS_TERMINATED, | 1111 registrar_.Remove(this, chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED, |
1111 NotificationService::AllSources()); | 1112 NotificationService::AllSources()); |
1112 registrar_.Remove(this, NotificationType::EXTENSION_HOST_DESTROYED, | 1113 registrar_.Remove(this, chrome::NOTIFICATION_EXTENSION_HOST_DESTROYED, |
1113 NotificationService::AllSources()); | 1114 NotificationService::AllSources()); |
1114 | 1115 |
1115 // Delete all the resources. | 1116 // Delete all the resources. |
1116 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); | 1117 STLDeleteContainerPairSecondPointers(resources_.begin(), resources_.end()); |
1117 | 1118 |
1118 resources_.clear(); | 1119 resources_.clear(); |
1119 pid_to_resources_.clear(); | 1120 pid_to_resources_.clear(); |
1120 } | 1121 } |
1121 | 1122 |
1122 void TaskManagerExtensionProcessResourceProvider::Observe( | 1123 void TaskManagerExtensionProcessResourceProvider::Observe( |
1123 NotificationType type, | 1124 int type, |
1124 const NotificationSource& source, | 1125 const NotificationSource& source, |
1125 const NotificationDetails& details) { | 1126 const NotificationDetails& details) { |
1126 switch (type.value) { | 1127 switch (type) { |
1127 case NotificationType::EXTENSION_PROCESS_CREATED: | 1128 case chrome::NOTIFICATION_EXTENSION_PROCESS_CREATED: |
1128 AddToTaskManager(Details<ExtensionHost>(details).ptr()); | 1129 AddToTaskManager(Details<ExtensionHost>(details).ptr()); |
1129 break; | 1130 break; |
1130 case NotificationType::EXTENSION_PROCESS_TERMINATED: | 1131 case chrome::NOTIFICATION_EXTENSION_PROCESS_TERMINATED: |
1131 case NotificationType::EXTENSION_HOST_DESTROYED: | 1132 case chrome::NOTIFICATION_EXTENSION_HOST_DESTROYED: |
1132 RemoveFromTaskManager(Details<ExtensionHost>(details).ptr()); | 1133 RemoveFromTaskManager(Details<ExtensionHost>(details).ptr()); |
1133 break; | 1134 break; |
1134 default: | 1135 default: |
1135 NOTREACHED() << "Unexpected notification."; | 1136 NOTREACHED() << "Unexpected notification."; |
1136 return; | 1137 return; |
1137 } | 1138 } |
1138 } | 1139 } |
1139 | 1140 |
1140 void TaskManagerExtensionProcessResourceProvider::AddToTaskManager( | 1141 void TaskManagerExtensionProcessResourceProvider::AddToTaskManager( |
1141 ExtensionHost* extension_host) { | 1142 ExtensionHost* extension_host) { |
(...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1306 | 1307 |
1307 return &resource_; | 1308 return &resource_; |
1308 } | 1309 } |
1309 | 1310 |
1310 void TaskManagerBrowserProcessResourceProvider::StartUpdating() { | 1311 void TaskManagerBrowserProcessResourceProvider::StartUpdating() { |
1311 task_manager_->AddResource(&resource_); | 1312 task_manager_->AddResource(&resource_); |
1312 } | 1313 } |
1313 | 1314 |
1314 void TaskManagerBrowserProcessResourceProvider::StopUpdating() { | 1315 void TaskManagerBrowserProcessResourceProvider::StopUpdating() { |
1315 } | 1316 } |
OLD | NEW |