Delete KeepBufferRefs helpers, and use of rtc::Bind.

The rtc::Bind usages are replaced with lambdas with copy-capture
of the ref pointers.

Bug: webrtc:11339
Change-Id: I2fb544fcd2780feac3d725993c360df91899b532
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/201201
Reviewed-by: Stefan Holmer <stefan@webrtc.org>
Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
Commit-Queue: Niels Moller <nisse@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#32946}
This commit is contained in:
Niels Möller
2021-01-11 13:26:35 +01:00
committed by Commit Bot
parent 4a5c855008
commit a68bfc5537
4 changed files with 14 additions and 35 deletions

View File

@ -14,7 +14,6 @@
#include "api/video/i420_buffer.h" #include "api/video/i420_buffer.h"
#include "common_video/include/video_frame_buffer.h" #include "common_video/include/video_frame_buffer.h"
#include "rtc_base/bind.h"
#include "rtc_base/checks.h" #include "rtc_base/checks.h"
#include "third_party/libyuv/include/libyuv.h" #include "third_party/libyuv/include/libyuv.h"
@ -138,10 +137,6 @@ int ConvertFromI420(const VideoFrame& src_frame,
ConvertVideoType(dst_video_type)); ConvertVideoType(dst_video_type));
} }
// Helper functions for keeping references alive.
void KeepBufferRefs(rtc::scoped_refptr<webrtc::VideoFrameBuffer>,
rtc::scoped_refptr<webrtc::VideoFrameBuffer>) {}
rtc::scoped_refptr<I420ABufferInterface> ScaleI420ABuffer( rtc::scoped_refptr<I420ABufferInterface> ScaleI420ABuffer(
const I420ABufferInterface& buffer, const I420ABufferInterface& buffer,
int target_width, int target_width,
@ -160,7 +155,8 @@ rtc::scoped_refptr<I420ABufferInterface> ScaleI420ABuffer(
yuv_buffer->StrideY(), yuv_buffer->DataU(), yuv_buffer->StrideU(), yuv_buffer->StrideY(), yuv_buffer->DataU(), yuv_buffer->StrideU(),
yuv_buffer->DataV(), yuv_buffer->StrideV(), axx_buffer->DataY(), yuv_buffer->DataV(), yuv_buffer->StrideV(), axx_buffer->DataY(),
axx_buffer->StrideY(), axx_buffer->StrideY(),
rtc::Bind(&KeepBufferRefs, yuv_buffer, axx_buffer)); // To keep references alive.
[yuv_buffer, axx_buffer] {});
return merged_buffer; return merged_buffer;
} }

View File

@ -20,11 +20,6 @@
#include "rtc_base/keep_ref_until_done.h" #include "rtc_base/keep_ref_until_done.h"
#include "rtc_base/logging.h" #include "rtc_base/logging.h"
namespace {
void KeepBufferRefs(rtc::scoped_refptr<webrtc::VideoFrameBuffer>,
rtc::scoped_refptr<webrtc::VideoFrameBuffer>) {}
} // anonymous namespace
namespace webrtc { namespace webrtc {
class MultiplexDecoderAdapter::AdapterDecodedImageCallback class MultiplexDecoderAdapter::AdapterDecodedImageCallback
@ -250,7 +245,8 @@ void MultiplexDecoderAdapter::MergeAlphaImages(
yuv_buffer->StrideY(), yuv_buffer->DataU(), yuv_buffer->StrideU(), yuv_buffer->StrideY(), yuv_buffer->DataU(), yuv_buffer->StrideU(),
yuv_buffer->DataV(), yuv_buffer->StrideV(), alpha_buffer->DataY(), yuv_buffer->DataV(), yuv_buffer->StrideV(), alpha_buffer->DataY(),
alpha_buffer->StrideY(), alpha_buffer->StrideY(),
rtc::Bind(&KeepBufferRefs, yuv_buffer, alpha_buffer)); // To keep references alive.
[yuv_buffer, alpha_buffer] {});
} }
if (supports_augmenting_data_) { if (supports_augmenting_data_) {
merged_buffer = rtc::scoped_refptr<webrtc::AugmentedVideoFrameBuffer>( merged_buffer = rtc::scoped_refptr<webrtc::AugmentedVideoFrameBuffer>(

View File

@ -12,29 +12,23 @@
#define RTC_BASE_KEEP_REF_UNTIL_DONE_H_ #define RTC_BASE_KEEP_REF_UNTIL_DONE_H_
#include "api/scoped_refptr.h" #include "api/scoped_refptr.h"
#include "rtc_base/bind.h"
#include "rtc_base/callback.h" #include "rtc_base/callback.h"
#include "rtc_base/ref_count.h"
namespace rtc { namespace rtc {
namespace impl {
template <class T>
static inline void DoNothing(const scoped_refptr<T>& object) {}
} // namespace impl
// KeepRefUntilDone keeps a reference to |object| until the returned // KeepRefUntilDone keeps a reference to |object| until the returned
// callback goes out of scope. If the returned callback is copied, the // callback goes out of scope. If the returned callback is copied, the
// reference will be released when the last callback goes out of scope. // reference will be released when the last callback goes out of scope.
template <class ObjectT> template <class ObjectT>
static inline Callback0<void> KeepRefUntilDone(ObjectT* object) { static inline Callback0<void> KeepRefUntilDone(ObjectT* object) {
return rtc::Bind(&impl::DoNothing<ObjectT>, scoped_refptr<ObjectT>(object)); scoped_refptr<ObjectT> p(object);
return [p] {};
} }
template <class ObjectT> template <class ObjectT>
static inline Callback0<void> KeepRefUntilDone( static inline Callback0<void> KeepRefUntilDone(
const scoped_refptr<ObjectT>& object) { const scoped_refptr<ObjectT>& object) {
return rtc::Bind(&impl::DoNothing<ObjectT>, object); return [object] {};
} }
} // namespace rtc } // namespace rtc

View File

@ -20,20 +20,12 @@
#include "api/video/video_rotation.h" #include "api/video/video_rotation.h"
#include "common_video/include/video_frame_buffer.h" #include "common_video/include/video_frame_buffer.h"
#include "common_video/libyuv/include/webrtc_libyuv.h" #include "common_video/libyuv/include/webrtc_libyuv.h"
#include "rtc_base/bind.h"
#include "rtc_base/checks.h" #include "rtc_base/checks.h"
#include "rtc_base/keep_ref_until_done.h" #include "rtc_base/keep_ref_until_done.h"
#include "test/frame_utils.h" #include "test/frame_utils.h"
namespace webrtc { namespace webrtc {
namespace test { namespace test {
namespace {
// Helper method for keeping a reference to passed pointers.
void KeepBufferRefs(rtc::scoped_refptr<webrtc::VideoFrameBuffer>,
rtc::scoped_refptr<webrtc::VideoFrameBuffer>) {}
} // namespace
SquareGenerator::SquareGenerator(int width, SquareGenerator::SquareGenerator(int width,
int height, int height,
@ -81,12 +73,13 @@ FrameGeneratorInterface::VideoFrameData SquareGenerator::NextFrame() {
CreateI420Buffer(width_, height_); CreateI420Buffer(width_, height_);
rtc::scoped_refptr<I420Buffer> axx_buffer = rtc::scoped_refptr<I420Buffer> axx_buffer =
CreateI420Buffer(width_, height_); CreateI420Buffer(width_, height_);
buffer = WrapI420ABuffer( buffer = WrapI420ABuffer(yuv_buffer->width(), yuv_buffer->height(),
yuv_buffer->width(), yuv_buffer->height(), yuv_buffer->DataY(), yuv_buffer->DataY(), yuv_buffer->StrideY(),
yuv_buffer->StrideY(), yuv_buffer->DataU(), yuv_buffer->StrideU(), yuv_buffer->DataU(), yuv_buffer->StrideU(),
yuv_buffer->DataV(), yuv_buffer->StrideV(), axx_buffer->DataY(), yuv_buffer->DataV(), yuv_buffer->StrideV(),
axx_buffer->StrideY(), axx_buffer->DataY(), axx_buffer->StrideY(),
rtc::Bind(&KeepBufferRefs, yuv_buffer, axx_buffer)); // To keep references alive.
[yuv_buffer, axx_buffer] {});
break; break;
} }
default: default: