| Index: content/renderer/media/webrtc/rtc_rtp_sender.cc
|
| diff --git a/content/renderer/media/webrtc/rtc_rtp_sender.cc b/content/renderer/media/webrtc/rtc_rtp_sender.cc
|
| index 2d61389b39d2a4c00c9739471dbfdd884682f0b3..e312e7f4c53849ca6a5c435135e4c3bacd261a36 100644
|
| --- a/content/renderer/media/webrtc/rtc_rtp_sender.cc
|
| +++ b/content/renderer/media/webrtc/rtc_rtp_sender.cc
|
| @@ -12,11 +12,12 @@ namespace content {
|
| namespace {
|
|
|
| inline bool operator==(
|
| - const std::unique_ptr<blink::WebMediaStreamTrack>& web_track,
|
| + const std::unique_ptr<WebRtcMediaStreamTrackAdapterMap::AdapterRef>&
|
| + track_adapter,
|
| const webrtc::MediaStreamTrackInterface* webrtc_track) {
|
| - if (!web_track)
|
| + if (!track_adapter)
|
| return !webrtc_track;
|
| - return webrtc_track && web_track->Id() == webrtc_track->id().c_str();
|
| + return track_adapter->webrtc_track() == webrtc_track;
|
| }
|
|
|
| } // namespace
|
| @@ -27,11 +28,12 @@ uintptr_t RTCRtpSender::getId(
|
| }
|
|
|
| RTCRtpSender::RTCRtpSender(
|
| - webrtc::RtpSenderInterface* webrtc_rtp_sender,
|
| - std::unique_ptr<blink::WebMediaStreamTrack> web_track)
|
| - : webrtc_rtp_sender_(webrtc_rtp_sender), web_track_(std::move(web_track)) {
|
| + scoped_refptr<webrtc::RtpSenderInterface> webrtc_rtp_sender,
|
| + std::unique_ptr<WebRtcMediaStreamTrackAdapterMap::AdapterRef> track_adapter)
|
| + : webrtc_rtp_sender_(std::move(webrtc_rtp_sender)),
|
| + track_adapter_(std::move(track_adapter)) {
|
| DCHECK(webrtc_rtp_sender_);
|
| - DCHECK(web_track_ == webrtc_track());
|
| + DCHECK(track_adapter_ == webrtc_rtp_sender_->track());
|
| }
|
|
|
| RTCRtpSender::~RTCRtpSender() {}
|
| @@ -41,12 +43,13 @@ uintptr_t RTCRtpSender::Id() const {
|
| }
|
|
|
| const blink::WebMediaStreamTrack* RTCRtpSender::Track() const {
|
| - DCHECK(web_track_ == webrtc_track());
|
| - return web_track_.get();
|
| + DCHECK(track_adapter_ == webrtc_rtp_sender_->track());
|
| + return track_adapter_ ? &track_adapter_->web_track() : nullptr;
|
| }
|
|
|
| const webrtc::MediaStreamTrackInterface* RTCRtpSender::webrtc_track() const {
|
| - return webrtc_rtp_sender_->track();
|
| + DCHECK(track_adapter_ == webrtc_rtp_sender_->track());
|
| + return track_adapter_ ? track_adapter_->webrtc_track() : nullptr;
|
| }
|
|
|
| } // namespace content
|
|
|