| 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;
|
| }
|
|
|