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 |