2018-04-19 09:04:13 +02:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2018 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.
|
|
|
|
|
*/
|
|
|
|
|
|
2018-09-28 09:07:24 +02:00
|
|
|
#ifndef TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
|
|
|
|
|
#define TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
|
2018-04-19 09:04:13 +02:00
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
Use absl::make_unique and absl::WrapUnique directly
Instead of going through our wrappers in ptr_util.h.
This CL was generated by the following script:
git grep -l ptr_util | xargs perl -pi -e 's,#include "rtc_base/ptr_util.h",#include "absl/memory/memory.h",'
git grep -l MakeUnique | xargs perl -pi -e 's,\b(rtc::)?MakeUnique\b,absl::make_unique,g'
git grep -l WrapUnique | xargs perl -pi -e 's,\b(rtc::)?WrapUnique\b,absl::WrapUnique,g'
git checkout -- rtc_base/ptr_util{.h,_unittest.cc}
git cl format
Followed by manually adding dependencies on
//third_party/abseil-cpp/absl/memory until `gn check` stopped
complaining.
Bug: webrtc:9473
Change-Id: I89ccd363f070479b8c431eb2c3d404a46eaacc1c
Reviewed-on: https://webrtc-review.googlesource.com/86600
Commit-Queue: Karl Wiberg <kwiberg@webrtc.org>
Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#23850}
2018-07-05 11:40:33 +02:00
|
|
|
#include "absl/memory/memory.h"
|
2018-04-19 09:04:13 +02:00
|
|
|
#include "api/video_codecs/video_encoder.h"
|
|
|
|
|
#include "api/video_codecs/video_encoder_factory.h"
|
|
|
|
|
|
|
|
|
|
namespace webrtc {
|
|
|
|
|
namespace test {
|
|
|
|
|
|
2019-06-11 14:57:57 +02:00
|
|
|
namespace {
|
|
|
|
|
const VideoEncoder::Capabilities kCapabilities(false);
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
// An encoder factory with a single underlying VideoEncoder object,
|
|
|
|
|
// intended for test purposes. Each call to CreateVideoEncoder returns
|
|
|
|
|
// a proxy for the same encoder, typically an instance of FakeEncoder.
|
2018-09-28 09:07:24 +02:00
|
|
|
class VideoEncoderProxyFactory final : public VideoEncoderFactory {
|
2018-04-19 09:04:13 +02:00
|
|
|
public:
|
2019-06-28 12:53:07 +02:00
|
|
|
explicit VideoEncoderProxyFactory(VideoEncoder* encoder)
|
|
|
|
|
: encoder_(encoder),
|
|
|
|
|
num_simultaneous_encoder_instances_(0),
|
|
|
|
|
max_num_simultaneous_encoder_instances_(0) {
|
2018-12-10 09:47:34 +00:00
|
|
|
codec_info_.is_hardware_accelerated = false;
|
|
|
|
|
codec_info_.has_internal_source = false;
|
|
|
|
|
}
|
2018-04-19 09:04:13 +02:00
|
|
|
|
|
|
|
|
// Unused by tests.
|
|
|
|
|
std::vector<SdpVideoFormat> GetSupportedFormats() const override {
|
|
|
|
|
RTC_NOTREACHED();
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
|
2018-12-10 09:47:34 +00:00
|
|
|
CodecInfo QueryVideoEncoder(const SdpVideoFormat& format) const override {
|
|
|
|
|
return codec_info_;
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
std::unique_ptr<VideoEncoder> CreateVideoEncoder(
|
|
|
|
|
const SdpVideoFormat& format) override {
|
2019-06-28 12:53:07 +02:00
|
|
|
++num_simultaneous_encoder_instances_;
|
|
|
|
|
max_num_simultaneous_encoder_instances_ =
|
|
|
|
|
std::max(max_num_simultaneous_encoder_instances_,
|
|
|
|
|
num_simultaneous_encoder_instances_);
|
|
|
|
|
return absl::make_unique<EncoderProxy>(encoder_, this);
|
2018-04-19 09:04:13 +02:00
|
|
|
}
|
|
|
|
|
|
2018-12-10 09:47:34 +00:00
|
|
|
void SetIsHardwareAccelerated(bool is_hardware_accelerated) {
|
|
|
|
|
codec_info_.is_hardware_accelerated = is_hardware_accelerated;
|
|
|
|
|
}
|
|
|
|
|
void SetHasInternalSource(bool has_internal_source) {
|
|
|
|
|
codec_info_.has_internal_source = has_internal_source;
|
|
|
|
|
}
|
|
|
|
|
|
2019-06-28 12:53:07 +02:00
|
|
|
int GetMaxNumberOfSimultaneousEncoderInstances() {
|
|
|
|
|
return max_num_simultaneous_encoder_instances_;
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
private:
|
2019-06-28 12:53:07 +02:00
|
|
|
void OnDestroyVideoEncoder() {
|
|
|
|
|
RTC_CHECK_GT(num_simultaneous_encoder_instances_, 0);
|
|
|
|
|
--num_simultaneous_encoder_instances_;
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
// Wrapper class, since CreateVideoEncoder needs to surrender
|
|
|
|
|
// ownership to the object it returns.
|
|
|
|
|
class EncoderProxy final : public VideoEncoder {
|
|
|
|
|
public:
|
2019-06-28 12:53:07 +02:00
|
|
|
explicit EncoderProxy(VideoEncoder* encoder,
|
|
|
|
|
VideoEncoderProxyFactory* encoder_factory)
|
|
|
|
|
: encoder_(encoder), encoder_factory_(encoder_factory) {}
|
|
|
|
|
~EncoderProxy() { encoder_factory_->OnDestroyVideoEncoder(); }
|
2018-04-19 09:04:13 +02:00
|
|
|
|
|
|
|
|
private:
|
2019-06-28 15:19:43 +02:00
|
|
|
void SetFecControllerOverride(
|
|
|
|
|
FecControllerOverride* fec_controller_override) override {
|
|
|
|
|
encoder_->SetFecControllerOverride(fec_controller_override);
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
int32_t Encode(const VideoFrame& input_image,
|
2019-03-07 10:18:23 +01:00
|
|
|
const std::vector<VideoFrameType>* frame_types) override {
|
2019-03-06 12:00:33 +01:00
|
|
|
return encoder_->Encode(input_image, frame_types);
|
2018-04-19 09:04:13 +02:00
|
|
|
}
|
2019-06-28 15:19:43 +02:00
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
int32_t InitEncode(const VideoCodec* config,
|
2019-06-11 14:57:57 +02:00
|
|
|
const Settings& settings) override {
|
|
|
|
|
return encoder_->InitEncode(config, settings);
|
2018-04-19 09:04:13 +02:00
|
|
|
}
|
2019-06-28 15:19:43 +02:00
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
int32_t RegisterEncodeCompleteCallback(
|
|
|
|
|
EncodedImageCallback* callback) override {
|
|
|
|
|
return encoder_->RegisterEncodeCompleteCallback(callback);
|
|
|
|
|
}
|
2019-06-28 15:19:43 +02:00
|
|
|
|
2018-04-19 09:04:13 +02:00
|
|
|
int32_t Release() override { return encoder_->Release(); }
|
2019-06-28 15:19:43 +02:00
|
|
|
|
2019-04-12 13:59:09 +02:00
|
|
|
void SetRates(const RateControlParameters& parameters) override {
|
|
|
|
|
encoder_->SetRates(parameters);
|
2018-04-19 09:04:13 +02:00
|
|
|
}
|
2019-06-28 15:19:43 +02:00
|
|
|
|
2018-11-01 17:45:06 +01:00
|
|
|
VideoEncoder::EncoderInfo GetEncoderInfo() const override {
|
|
|
|
|
return encoder_->GetEncoderInfo();
|
2018-04-19 09:04:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
VideoEncoder* const encoder_;
|
2019-06-28 12:53:07 +02:00
|
|
|
VideoEncoderProxyFactory* const encoder_factory_;
|
2018-04-19 09:04:13 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
VideoEncoder* const encoder_;
|
2018-12-10 09:47:34 +00:00
|
|
|
CodecInfo codec_info_;
|
2019-06-28 12:53:07 +02:00
|
|
|
|
|
|
|
|
int num_simultaneous_encoder_instances_;
|
|
|
|
|
int max_num_simultaneous_encoder_instances_;
|
2018-04-19 09:04:13 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace test
|
|
|
|
|
} // namespace webrtc
|
|
|
|
|
|
2018-09-28 09:07:24 +02:00
|
|
|
#endif // TEST_VIDEO_ENCODER_PROXY_FACTORY_H_
|