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

Unified Diff: content/renderer/media/media_stream_dispatcher.cc

Issue 9903014: Using WeakPtr for requests to MediaStreamDispatcher. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase Created 8 years, 8 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: content/renderer/media/media_stream_dispatcher.cc
diff --git a/content/renderer/media/media_stream_dispatcher.cc b/content/renderer/media/media_stream_dispatcher.cc
index 254740a6c31ee0013f48993d2ffe18230d08c7ff..cdf1d02b12661cb34e19ccf8e0fa5c2125ac6fb2 100644
--- a/content/renderer/media/media_stream_dispatcher.cc
+++ b/content/renderer/media/media_stream_dispatcher.cc
@@ -10,22 +10,22 @@
#include "content/renderer/render_view_impl.h"
struct MediaStreamDispatcher::Request {
- Request(MediaStreamDispatcherEventHandler* handler,
+ Request(const base::WeakPtr<MediaStreamDispatcherEventHandler>& handler,
int request_id,
int ipc_request)
: handler(handler),
request_id(request_id),
ipc_request(ipc_request) {
}
- MediaStreamDispatcherEventHandler* handler;
+ base::WeakPtr<MediaStreamDispatcherEventHandler> handler;
int request_id;
int ipc_request;
};
struct MediaStreamDispatcher::Stream {
- Stream() : handler(NULL) {}
+ Stream() {}
~Stream() {}
- MediaStreamDispatcherEventHandler* handler;
+ base::WeakPtr<MediaStreamDispatcherEventHandler> handler;
media_stream::StreamDeviceInfoArray audio_array;
media_stream::StreamDeviceInfoArray video_array;
};
@@ -39,7 +39,7 @@ MediaStreamDispatcher::~MediaStreamDispatcher() {}
void MediaStreamDispatcher::GenerateStream(
int request_id,
- MediaStreamDispatcherEventHandler* event_handler,
+ const base::WeakPtr<MediaStreamDispatcherEventHandler>& event_handler,
media_stream::StreamOptions components,
const std::string& security_origin) {
DVLOG(1) << "MediaStreamDispatcher::GenerateStream(" << request_id << ")";
@@ -65,7 +65,7 @@ void MediaStreamDispatcher::StopStream(const std::string& label) {
void MediaStreamDispatcher::EnumerateDevices(
int request_id,
- MediaStreamDispatcherEventHandler* event_handler,
+ const base::WeakPtr<MediaStreamDispatcherEventHandler>& event_handler,
media_stream::MediaStreamType type,
const std::string& security_origin) {
DVLOG(1) << "MediaStreamDispatcher::EnumerateDevices("
@@ -80,7 +80,7 @@ void MediaStreamDispatcher::EnumerateDevices(
void MediaStreamDispatcher::OpenDevice(
int request_id,
- MediaStreamDispatcherEventHandler* event_handler,
+ const base::WeakPtr<MediaStreamDispatcherEventHandler>& event_handler,
const std::string& device_id,
media_stream::MediaStreamType type,
const std::string& security_origin) {
@@ -140,10 +140,12 @@ void MediaStreamDispatcher::OnStreamGenerated(
new_stream.audio_array = audio_array;
new_stream.video_array = video_array;
label_stream_map_[label] = new_stream;
- request.handler->OnStreamGenerated(request.request_id, label,
- audio_array, video_array);
- DVLOG(1) << "MediaStreamDispatcher::OnStreamGenerated("
- << request.request_id << ", " << label << ")";
+ if (request.handler) {
+ request.handler->OnStreamGenerated(request.request_id, label,
+ audio_array, video_array);
+ DVLOG(1) << "MediaStreamDispatcher::OnStreamGenerated("
+ << request.request_id << ", " << label << ")";
+ }
requests_.erase(it);
break;
}
@@ -155,9 +157,11 @@ void MediaStreamDispatcher::OnStreamGenerationFailed(int request_id) {
it != requests_.end(); ++it) {
Request& request = *it;
if (request.ipc_request == request_id) {
- request.handler->OnStreamGenerationFailed(request.request_id);
- DVLOG(1) << "MediaStreamDispatcher::OnStreamGenerationFailed("
- << request.request_id << ")\n";
+ if (request.handler) {
+ request.handler->OnStreamGenerationFailed(request.request_id);
+ DVLOG(1) << "MediaStreamDispatcher::OnStreamGenerationFailed("
+ << request.request_id << ")\n";
+ }
requests_.erase(it);
break;
}
@@ -175,7 +179,8 @@ void MediaStreamDispatcher::OnVideoDeviceFailed(const std::string& label,
media_stream::StreamDeviceInfoArray::iterator device_it =
it->second.video_array.begin();
it->second.video_array.erase(device_it + index);
- it->second.handler->OnVideoDeviceFailed(label, index);
+ if (it->second.handler)
+ it->second.handler->OnVideoDeviceFailed(label, index);
}
void MediaStreamDispatcher::OnAudioDeviceFailed(const std::string& label,
@@ -189,7 +194,8 @@ void MediaStreamDispatcher::OnAudioDeviceFailed(const std::string& label,
media_stream::StreamDeviceInfoArray::iterator device_it =
it->second.audio_array.begin();
it->second.audio_array.erase(device_it + index);
- it->second.handler->OnAudioDeviceFailed(label, index);
+ if (it->second.handler)
+ it->second.handler->OnAudioDeviceFailed(label, index);
}
void MediaStreamDispatcher::OnDevicesEnumerated(
@@ -200,9 +206,11 @@ void MediaStreamDispatcher::OnDevicesEnumerated(
it != requests_.end(); ++it) {
Request& request = *it;
if (request.ipc_request == request_id) {
- request.handler->OnDevicesEnumerated(request.request_id, device_array);
- DVLOG(1) << "MediaStreamDispatcher::OnDevicesEnumerated("
- << request.request_id << ")";
+ if (request.handler) {
+ request.handler->OnDevicesEnumerated(request.request_id, device_array);
+ DVLOG(1) << "MediaStreamDispatcher::OnDevicesEnumerated("
+ << request.request_id << ")";
+ }
requests_.erase(it);
break;
}
@@ -214,9 +222,11 @@ void MediaStreamDispatcher::OnDevicesEnumerationFailed(int request_id) {
it != requests_.end(); ++it) {
Request& request = *it;
if (request.ipc_request == request_id) {
- request.handler->OnStreamGenerationFailed(request.request_id);
- DVLOG(1) << "MediaStreamDispatcher::OnDevicesEnumerationFailed("
- << request.request_id << ")\n";
+ if (request.handler) {
+ request.handler->OnStreamGenerationFailed(request.request_id);
+ DVLOG(1) << "MediaStreamDispatcher::OnDevicesEnumerationFailed("
+ << request.request_id << ")\n";
+ }
requests_.erase(it);
break;
}
@@ -240,10 +250,12 @@ void MediaStreamDispatcher::OnDeviceOpened(
new_stream.audio_array.push_back(device_info);
}
label_stream_map_[label] = new_stream;
- request.handler->OnDeviceOpened(request.request_id, label,
- device_info);
- DVLOG(1) << "MediaStreamDispatcher::OnDeviceOpened("
- << request.request_id << ", " << label << ")";
+ if (request.handler) {
+ request.handler->OnDeviceOpened(request.request_id, label,
+ device_info);
+ DVLOG(1) << "MediaStreamDispatcher::OnDeviceOpened("
+ << request.request_id << ", " << label << ")";
+ }
requests_.erase(it);
break;
}
@@ -255,9 +267,11 @@ void MediaStreamDispatcher::OnDeviceOpenFailed(int request_id) {
it != requests_.end(); ++it) {
Request& request = *it;
if (request.ipc_request == request_id) {
- request.handler->OnDeviceOpenFailed(request.request_id);
- DVLOG(1) << "MediaStreamDispatcher::OnDeviceOpenFailed("
- << request.request_id << ")\n";
+ if (request.handler) {
+ request.handler->OnDeviceOpenFailed(request.request_id);
+ DVLOG(1) << "MediaStreamDispatcher::OnDeviceOpenFailed("
+ << request.request_id << ")\n";
+ }
requests_.erase(it);
break;
}
« no previous file with comments | « content/renderer/media/media_stream_dispatcher.h ('k') | content/renderer/media/media_stream_dispatcher_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698