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

Unified Diff: talk/media/webrtc/webrtcvoiceengine.cc

Issue 1551813002: Storing raw audio sink for default audio track. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Adding unit tests for SetRawAudioSink. Created 4 years, 11 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: talk/media/webrtc/webrtcvoiceengine.cc
diff --git a/talk/media/webrtc/webrtcvoiceengine.cc b/talk/media/webrtc/webrtcvoiceengine.cc
index 9eee2af20219d710bfad79104c047ad905f33c76..e125898103d814dfa49fa99caee842e9ba163257 100644
--- a/talk/media/webrtc/webrtcvoiceengine.cc
+++ b/talk/media/webrtc/webrtcvoiceengine.cc
@@ -1244,9 +1244,9 @@ class WebRtcVoiceMediaChannel::WebRtcAudioReceiveStream {
return config_.voe_channel_id;
}
- void SetRawAudioSink(rtc::scoped_ptr<webrtc::AudioSinkInterface> sink) {
+ void SetRawAudioSink(rtc::scoped_refptr<webrtc::AudioSinkInterface> sink) {
RTC_DCHECK(worker_thread_checker_.CalledOnValidThread());
- stream_->SetSink(std::move(sink));
+ stream_->SetSink(sink);
}
private:
@@ -2186,6 +2186,9 @@ void WebRtcVoiceMediaChannel::OnPacketReceived(
}
default_recv_ssrc_ = ssrc;
SetOutputVolume(default_recv_ssrc_, default_recv_volume_);
+ if (default_sink_) {
the sun 2016/01/08 13:14:26 No need for the conditional, setting a null sink s
Taylor Brandstetter 2016/01/08 19:46:58 Done.
+ SetRawAudioSink(default_recv_ssrc_, default_sink_);
+ }
}
// Forward packet to Call. If the SSRC is unknown we'll return after this.
@@ -2412,15 +2415,22 @@ bool WebRtcVoiceMediaChannel::GetStats(VoiceMediaInfo* info) {
void WebRtcVoiceMediaChannel::SetRawAudioSink(
uint32_t ssrc,
- rtc::scoped_ptr<webrtc::AudioSinkInterface> sink) {
+ rtc::scoped_refptr<webrtc::AudioSinkInterface> sink) {
RTC_DCHECK(worker_thread_checker_.CalledOnValidThread());
LOG(LS_VERBOSE) << "WebRtcVoiceMediaChannel::SetRawAudioSink";
+ if (ssrc == 0) {
+ default_sink_ = sink;
+ if (default_recv_ssrc_ != -1) {
+ SetRawAudioSink(default_recv_ssrc_, sink);
the sun 2016/01/08 13:14:26 Nice, but will generate duplicate log lines. I'd p
Taylor Brandstetter 2016/01/08 19:46:58 Done.
+ }
+ return;
+ }
const auto it = recv_streams_.find(ssrc);
if (it == recv_streams_.end()) {
LOG(LS_WARNING) << "SetRawAudioSink: no recv stream" << ssrc;
return;
}
- it->second->SetRawAudioSink(std::move(sink));
+ it->second->SetRawAudioSink(sink);
}
int WebRtcVoiceMediaChannel::GetOutputLevel(int channel) {

Powered by Google App Engine
This is Rietveld 408576698