| 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/extensions/api/tab_capture/tab_capture_registry.h" | 5 #include "chrome/browser/extensions/api/tab_capture/tab_capture_registry.h" |
| 6 | 6 |
| 7 #include "base/lazy_instance.h" | 7 #include "base/lazy_instance.h" |
| 8 #include "chrome/browser/chrome_notification_types.h" | 8 #include "chrome/browser/chrome_notification_types.h" |
| 9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
| 10 #include "chrome/browser/ui/fullscreen/fullscreen_controller.h" | 10 #include "chrome/browser/ui/fullscreen/fullscreen_controller.h" |
| (...skipping 91 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 102 fullscreen(false) { | 102 fullscreen(false) { |
| 103 } | 103 } |
| 104 | 104 |
| 105 TabCaptureRequest::~TabCaptureRequest() { | 105 TabCaptureRequest::~TabCaptureRequest() { |
| 106 } | 106 } |
| 107 | 107 |
| 108 TabCaptureRegistry::TabCaptureRegistry(content::BrowserContext* context) | 108 TabCaptureRegistry::TabCaptureRegistry(content::BrowserContext* context) |
| 109 : profile_(Profile::FromBrowserContext(context)) { | 109 : profile_(Profile::FromBrowserContext(context)) { |
| 110 MediaCaptureDevicesDispatcher::GetInstance()->AddObserver(this); | 110 MediaCaptureDevicesDispatcher::GetInstance()->AddObserver(this); |
| 111 registrar_.Add(this, | 111 registrar_.Add(this, |
| 112 chrome::NOTIFICATION_EXTENSION_UNLOADED, | 112 chrome::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED, |
| 113 content::Source<Profile>(profile_)); | 113 content::Source<Profile>(profile_)); |
| 114 registrar_.Add(this, | 114 registrar_.Add(this, |
| 115 chrome::NOTIFICATION_FULLSCREEN_CHANGED, | 115 chrome::NOTIFICATION_FULLSCREEN_CHANGED, |
| 116 content::NotificationService::AllSources()); | 116 content::NotificationService::AllSources()); |
| 117 } | 117 } |
| 118 | 118 |
| 119 TabCaptureRegistry::~TabCaptureRegistry() { | 119 TabCaptureRegistry::~TabCaptureRegistry() { |
| 120 MediaCaptureDevicesDispatcher::GetInstance()->RemoveObserver(this); | 120 MediaCaptureDevicesDispatcher::GetInstance()->RemoveObserver(this); |
| 121 } | 121 } |
| 122 | 122 |
| (...skipping 22 matching lines...) Expand all Loading... |
| 145 } | 145 } |
| 146 } | 146 } |
| 147 return list; | 147 return list; |
| 148 } | 148 } |
| 149 | 149 |
| 150 void TabCaptureRegistry::Observe(int type, | 150 void TabCaptureRegistry::Observe(int type, |
| 151 const content::NotificationSource& source, | 151 const content::NotificationSource& source, |
| 152 const content::NotificationDetails& details) { | 152 const content::NotificationDetails& details) { |
| 153 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 153 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 154 switch (type) { | 154 switch (type) { |
| 155 case chrome::NOTIFICATION_EXTENSION_UNLOADED: { | 155 case chrome::NOTIFICATION_EXTENSION_UNLOADED_DEPRECATED: { |
| 156 // Cleanup all the requested media streams for this extension. | 156 // Cleanup all the requested media streams for this extension. |
| 157 const std::string& extension_id = | 157 const std::string& extension_id = |
| 158 content::Details<extensions::UnloadedExtensionInfo>(details)-> | 158 content::Details<extensions::UnloadedExtensionInfo>(details)-> |
| 159 extension->id(); | 159 extension->id(); |
| 160 for (ScopedVector<TabCaptureRequest>::iterator it = requests_.begin(); | 160 for (ScopedVector<TabCaptureRequest>::iterator it = requests_.begin(); |
| 161 it != requests_.end();) { | 161 it != requests_.end();) { |
| 162 if ((*it)->extension_id == extension_id) { | 162 if ((*it)->extension_id == extension_id) { |
| 163 it = requests_.erase(it); | 163 it = requests_.erase(it); |
| 164 } else { | 164 } else { |
| 165 ++it; | 165 ++it; |
| (...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 353 it != requests_.end(); ++it) { | 353 it != requests_.end(); ++it) { |
| 354 if ((*it)->render_process_id == render_process_id && | 354 if ((*it)->render_process_id == render_process_id && |
| 355 (*it)->render_view_id == render_view_id) { | 355 (*it)->render_view_id == render_view_id) { |
| 356 requests_.erase(it); | 356 requests_.erase(it); |
| 357 return; | 357 return; |
| 358 } | 358 } |
| 359 } | 359 } |
| 360 } | 360 } |
| 361 | 361 |
| 362 } // namespace extensions | 362 } // namespace extensions |
| OLD | NEW |