Chromium Code Reviews| Index: webrtc/sdk/android/src/jni/createpeerconnectionfactory_datachannelonly.cc |
| diff --git a/webrtc/sdk/android/src/jni/createpeerconnectionfactory_datachannelonly.cc b/webrtc/sdk/android/src/jni/createpeerconnectionfactory_datachannelonly.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..7d0d30b2161d45f51c1f7b0964677ecb89c69738 |
| --- /dev/null |
| +++ b/webrtc/sdk/android/src/jni/createpeerconnectionfactory_datachannelonly.cc |
| @@ -0,0 +1,106 @@ |
| +/* |
|
magjed_webrtc
2017/06/13 15:14:31
This is a file I haven't seen before and it's not
Zhi Huang
2017/06/14 06:57:01
Agree. It would be much better to put them to null
|
| + * Copyright 2017 The WebRTC project authors. All Rights Reserved. |
| + * |
| + * Use of this source code is governed by a BSD-style license |
| + * that can be found in the LICENSE file in the root of the source |
| + * tree. An additional intellectual property rights grant can be found |
| + * in the file PATENTS. All contributing project authors may |
| + * be found in the AUTHORS file in the root of the source tree. |
| + */ |
| + |
| +#include "webrtc/api/peerconnectioninterface.h" |
| +#include "webrtc/base/bind.h" |
| +#include "webrtc/base/scoped_ref_ptr.h" |
| +#include "webrtc/base/thread.h" |
| +#include "webrtc/call/callfactoryinterface.h" |
| +#include "webrtc/media/engine/webrtcmediaengine.h" // nogncheck |
| + |
| +namespace webrtc { |
| + |
| +rtc::scoped_refptr<PeerConnectionFactoryInterface> CreatePeerConnectionFactory( |
|
the sun
2017/06/13 14:34:39
Do you really need all of these functions? Isn't t
Zhi Huang
2017/06/14 06:57:00
You are right. I'll try to remove the unused ones.
|
| + rtc::scoped_refptr<AudioEncoderFactory> audio_encoder_factory, |
| + rtc::scoped_refptr<AudioDecoderFactory> audio_decoder_factory) { |
| + // Create and start the worker thread to create the MediaEngine. |
| + std::unique_ptr<rtc::Thread> worker_thread = rtc::Thread::Create(); |
| + worker_thread->Start(); |
| + |
| + return CreateModularPeerConnectionFactory( |
| + nullptr, /*network_thread*/ |
| + worker_thread.release(), nullptr /*signaling_thread*/, |
| + nullptr /*default_adm*/, audio_encoder_factory, audio_decoder_factory, |
| + nullptr /*video_encoder_factory*/, nullptr /*video_decoder_factory*/, |
| + nullptr /*audio_mixer*/, std::unique_ptr<cricket::MediaEngineInterface>(), |
| + std::unique_ptr<CallFactoryInterface>(), |
| + std::unique_ptr<RtcEventLogFactoryInterface>()); |
| +} |
| + |
| +rtc::scoped_refptr<PeerConnectionFactoryInterface> |
| +CreatePeerConnectionFactory() { |
| + return CreatePeerConnectionFactory(nullptr /*AudioEncoderFactory*/, |
| + nullptr /*AudioDecoderFactory*/); |
| +} |
| + |
| +rtc::scoped_refptr<PeerConnectionFactoryInterface> |
| +CreatePeerConnectionFactoryWithAudioMixer( |
| + rtc::Thread* network_thread, |
| + rtc::Thread* worker_thread, |
| + rtc::Thread* signaling_thread, |
| + AudioDeviceModule* default_adm, |
| + rtc::scoped_refptr<AudioEncoderFactory> audio_encoder_factory, |
| + rtc::scoped_refptr<AudioDecoderFactory> audio_decoder_factory, |
| + cricket::WebRtcVideoEncoderFactory* video_encoder_factory, |
| + cricket::WebRtcVideoDecoderFactory* video_decoder_factory, |
| + rtc::scoped_refptr<AudioMixer> audio_mixer) { |
| + return CreateModularPeerConnectionFactory( |
| + network_thread, worker_thread, signaling_thread, default_adm, |
| + audio_encoder_factory, audio_decoder_factory, video_encoder_factory, |
| + video_decoder_factory, audio_mixer, |
| + std::unique_ptr<cricket::MediaEngineInterface>(), |
| + std::unique_ptr<CallFactoryInterface>(), |
| + std::unique_ptr<RtcEventLogFactoryInterface>()); |
| +} |
| + |
| +rtc::scoped_refptr<PeerConnectionFactoryInterface> |
| +CreatePeerConnectionFactoryWithAudioMixer( |
| + rtc::Thread* network_thread, |
| + rtc::Thread* worker_thread, |
| + rtc::Thread* signaling_thread, |
| + AudioDeviceModule* default_adm, |
| + cricket::WebRtcVideoEncoderFactory* encoder_factory, |
| + cricket::WebRtcVideoDecoderFactory* decoder_factory, |
| + rtc::scoped_refptr<AudioMixer> audio_mixer) { |
| + return CreatePeerConnectionFactoryWithAudioMixer( |
| + network_thread, worker_thread, signaling_thread, default_adm, |
| + nullptr, /*AudioEncoderFactory*/ |
| + nullptr /*AudioDecoderFactory*/, encoder_factory, decoder_factory, |
| + audio_mixer); |
| +} |
| + |
| +rtc::scoped_refptr<PeerConnectionFactoryInterface> CreatePeerConnectionFactory( |
| + rtc::Thread* network_thread, |
| + rtc::Thread* worker_thread, |
| + rtc::Thread* signaling_thread, |
| + AudioDeviceModule* default_adm, |
| + cricket::WebRtcVideoEncoderFactory* encoder_factory, |
| + cricket::WebRtcVideoDecoderFactory* decoder_factory) { |
| + return CreatePeerConnectionFactoryWithAudioMixer( |
| + network_thread, worker_thread, signaling_thread, default_adm, |
| + encoder_factory, decoder_factory, nullptr); |
| +} |
| + |
| +rtc::scoped_refptr<PeerConnectionFactoryInterface> CreatePeerConnectionFactory( |
| + rtc::Thread* network_thread, |
| + rtc::Thread* worker_thread, |
| + rtc::Thread* signaling_thread, |
| + AudioDeviceModule* default_adm, |
| + rtc::scoped_refptr<AudioEncoderFactory> audio_encoder_factory, |
| + rtc::scoped_refptr<AudioDecoderFactory> audio_decoder_factory, |
| + cricket::WebRtcVideoEncoderFactory* video_encoder_factory, |
| + cricket::WebRtcVideoDecoderFactory* video_decoder_factory) { |
| + return CreatePeerConnectionFactoryWithAudioMixer( |
| + network_thread, worker_thread, signaling_thread, default_adm, |
| + audio_encoder_factory, audio_decoder_factory, video_encoder_factory, |
| + video_decoder_factory, nullptr); |
| +} |
| + |
| +} // namespace webrtc |