Fixes session state transition and registering observer.

Review URL: http://webrtc-codereview.appspot.com/203001

git-svn-id: http://webrtc.googlecode.com/svn/trunk@697 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
mallinath@webrtc.org 2011-10-05 22:49:59 +00:00
parent 01ca01f6e6
commit fa41d807a8
2 changed files with 15 additions and 13 deletions

View File

@ -149,6 +149,8 @@ PeerConnectionImpl::PeerConnectionImpl(
this, &PeerConnectionImpl::OnRemoteStreamAdded); this, &PeerConnectionImpl::OnRemoteStreamAdded);
signaling_->SignalRemoteStreamRemoved.connect( signaling_->SignalRemoteStreamRemoved.connect(
this, &PeerConnectionImpl::OnRemoteStreamRemoved); this, &PeerConnectionImpl::OnRemoteStreamRemoved);
// Register with WebRtcSession
session_->RegisterObserver(signaling_.get());
} }
PeerConnectionImpl::~PeerConnectionImpl() { PeerConnectionImpl::~PeerConnectionImpl() {

View File

@ -131,7 +131,8 @@ void WebRtcSession::SetRemoteCandidates(
cricket::TransportProxy* audio_proxy = GetTransportProxy(cricket::CN_AUDIO); cricket::TransportProxy* audio_proxy = GetTransportProxy(cricket::CN_AUDIO);
if (audio_proxy) { if (audio_proxy) {
// CompleteNegotiation will set actual impl's in Proxy. // CompleteNegotiation will set actual impl's in Proxy.
audio_proxy->CompleteNegotiation(); if (!audio_proxy->negotiated())
audio_proxy->CompleteNegotiation();
// TODO(mallinath) - Add a interface to TransportProxy to accept // TODO(mallinath) - Add a interface to TransportProxy to accept
// remote candidate list. // remote candidate list.
audio_proxy->impl()->OnRemoteCandidates(audio_candidates); audio_proxy->impl()->OnRemoteCandidates(audio_candidates);
@ -144,7 +145,8 @@ void WebRtcSession::SetRemoteCandidates(
cricket::TransportProxy* video_proxy = GetTransportProxy(cricket::CN_VIDEO); cricket::TransportProxy* video_proxy = GetTransportProxy(cricket::CN_VIDEO);
if (video_proxy) { if (video_proxy) {
// CompleteNegotiation will set actual impl's in Proxy. // CompleteNegotiation will set actual impl's in Proxy.
video_proxy->CompleteNegotiation(); if (!video_proxy->negotiated())
video_proxy->CompleteNegotiation();
// TODO(mallinath) - Add a interface to TransportProxy to accept // TODO(mallinath) - Add a interface to TransportProxy to accept
// remote candidate list. // remote candidate list.
video_proxy->impl()->OnRemoteCandidates(video_candidates); video_proxy->impl()->OnRemoteCandidates(video_candidates);
@ -278,15 +280,17 @@ const cricket::SessionDescription* WebRtcSession::ProvideAnswer(
} }
void WebRtcSession::NegotiationDone() { void WebRtcSession::NegotiationDone() {
// No state change after state moved to progress state. // SetState of session is called after session receives both local and
// remote descriptions. State transition will happen only when session
// is in INIT state.
if (state() == STATE_INIT) { if (state() == STATE_INIT) {
SetState(STATE_SENTINITIATE); SetState(STATE_SENTINITIATE);
SetState(STATE_RECEIVEDACCEPT); SetState(STATE_RECEIVEDACCEPT);
}
// Enabling channels // Enabling voice and video channel.
voice_channel_->Enable(true); voice_channel_->Enable(true);
video_channel_->Enable(true); video_channel_->Enable(true);
}
const cricket::ContentInfo* audio_info = const cricket::ContentInfo* audio_info =
cricket::GetFirstAudioContent(local_description()); cricket::GetFirstAudioContent(local_description());
@ -298,9 +302,7 @@ void WebRtcSession::NegotiationDone() {
// we can remove stream from a session by muting it. // we can remove stream from a session by muting it.
// TODO(mallinath) - Change needed when multiple send streams support // TODO(mallinath) - Change needed when multiple send streams support
// is available. // is available.
if (audio_content->sources().size() == 0) { voice_channel_->Mute(audio_content->sources().size() == 0);
voice_channel_->Mute(true);
}
} }
const cricket::ContentInfo* video_info = const cricket::ContentInfo* video_info =
@ -313,9 +315,7 @@ void WebRtcSession::NegotiationDone() {
// we can remove stream from a session by muting it. // we can remove stream from a session by muting it.
// TODO(mallinath) - Change needed when multiple send streams support // TODO(mallinath) - Change needed when multiple send streams support
// is available. // is available.
if (video_content->sources().size() == 0) { video_channel_->Mute(video_content->sources().size() == 0);
video_channel_->Mute(true);
}
} }
} }