 Chromium Code Reviews
 Chromium Code Reviews Issue 2979983002:
  Reland of Injectable Obj-C video codecs  (Closed)
    
  
    Issue 2979983002:
  Reland of Injectable Obj-C video codecs  (Closed) 
  | Index: webrtc/sdk/objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm | 
| diff --git a/webrtc/sdk/objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm b/webrtc/sdk/objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm | 
| index 7accdbbe38752ea85c0b9ae93e2c410f74d152a9..7c5ba1d16f7e18f1003642fa94aafda8e5bf594c 100644 | 
| --- a/webrtc/sdk/objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm | 
| +++ b/webrtc/sdk/objc/Framework/Classes/PeerConnection/RTCPeerConnectionFactory.mm | 
| @@ -11,6 +11,7 @@ | 
| #import "RTCPeerConnectionFactory+Private.h" | 
| #import "NSString+StdString.h" | 
| +#import "RTCAVFoundationVideoSource+Private.h" | 
| #import "RTCAudioSource+Private.h" | 
| #import "RTCAudioTrack+Private.h" | 
| #import "RTCMediaConstraints+Private.h" | 
| @@ -18,11 +19,15 @@ | 
| #import "RTCPeerConnection+Private.h" | 
| #import "RTCVideoSource+Private.h" | 
| #import "RTCVideoTrack+Private.h" | 
| -#import "RTCAVFoundationVideoSource+Private.h" | 
| #import "WebRTC/RTCLogging.h" | 
| +#import "WebRTC/RTCVideoCodecFactory.h" | 
| +#ifndef HAVE_NO_MEDIA | 
| +#import "WebRTC/RTCVideoCodecH264.h" | 
| +#endif | 
| +#include "PeerConnection/objc_video_decoder_factory.h" | 
| +#include "PeerConnection/objc_video_encoder_factory.h" | 
| #include "Video/objcvideotracksource.h" | 
| -#include "VideoToolbox/videocodecfactory.h" | 
| #include "webrtc/api/videosourceproxy.h" | 
| // Adding the nogncheck to disable the including header check. | 
| // The no-media version PeerConnectionFactory doesn't depend on media related | 
| @@ -41,7 +46,17 @@ | 
| @synthesize nativeFactory = _nativeFactory; | 
| - (instancetype)init { | 
| - if ((self = [super init])) { | 
| +#ifdef HAVE_NO_MEDIA | 
| + return [self initWithEncoderFactory:nil decoderFactory:nil]; | 
| +#else | 
| + return [self initWithEncoderFactory:[[RTCVideoEncoderFactoryH264 alloc] init] | 
| + decoderFactory:[[RTCVideoDecoderFactoryH264 alloc] init]]; | 
| +#endif | 
| +} | 
| + | 
| +- (instancetype)initWithEncoderFactory:(nullable id<RTCVideoEncoderFactory>)encoderFactory | 
| + decoderFactory:(nullable id<RTCVideoDecoderFactory>)decoderFactory { | 
| + if (self = [super init]) { | 
| _networkThread = rtc::Thread::CreateWithSocketServer(); | 
| BOOL result = _networkThread->Start(); | 
| NSAssert(result, @"Failed to start network thread."); | 
| @@ -68,8 +83,14 @@ | 
| std::unique_ptr<webrtc::CallFactoryInterface>(), | 
| std::unique_ptr<webrtc::RtcEventLogFactoryInterface>()); | 
| #else | 
| - const auto encoder_factory = new webrtc::VideoToolboxVideoEncoderFactory(); | 
| - const auto decoder_factory = new webrtc::VideoToolboxVideoDecoderFactory(); | 
| + cricket::WebRtcVideoEncoderFactory *encoder_factory = nullptr; | 
| + cricket::WebRtcVideoDecoderFactory *decoder_factory = nullptr; | 
| + if (encoderFactory) { | 
| 
Chuck
2017/07/14 14:57:29
Both jtteh and I misread this code on the first pa
 | 
| + encoder_factory = new webrtc::ObjCVideoEncoderFactory(encoderFactory); | 
| + } | 
| + if (decoderFactory) { | 
| + decoder_factory = new webrtc::ObjCVideoDecoderFactory(decoderFactory); | 
| + } | 
| // Ownership of encoder/decoder factories is passed on to the | 
| // peerconnectionfactory, that handles deleting them. |