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:
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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>(
|
||||||
|
@ -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
|
||||||
|
@ -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:
|
||||||
|
Reference in New Issue
Block a user