Files
platform-external-webrtc/api/test/video/video_frame_writer.h
Artem Titov 2068d0daa7 [PCLF] Add ability to provide custom VideoFrameWriter
Bug: b/240540204
Change-Id: Ica85954ea61b7caf4e2d726895b6a439b47d7bbb
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/278800
Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org>
Reviewed-by: Danil Chapovalov <danilchap@webrtc.org>
Commit-Queue: Artem Titov <titovartem@webrtc.org>
Cr-Commit-Position: refs/heads/main@{#38368}
2022-10-12 14:08:00 +00:00

38 lines
1.1 KiB
C++

/*
* Copyright (c) 2022 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.
*/
#ifndef API_TEST_VIDEO_VIDEO_FRAME_WRITER_H_
#define API_TEST_VIDEO_VIDEO_FRAME_WRITER_H_
#include "api/video/video_frame.h"
namespace webrtc {
namespace test {
class VideoFrameWriter {
public:
virtual ~VideoFrameWriter() = default;
// Writes `VideoFrame` and returns true if operation was successful, false
// otherwise.
//
// Calling `WriteFrame` after `Close` is not allowed.
virtual bool WriteFrame(const VideoFrame& frame) = 0;
// Closes writer and cleans up all resources. No invocations to `WriteFrame`
// are allowed after `Close` was invoked.
virtual void Close() = 0;
};
} // namespace test
} // namespace webrtc
#endif // API_TEST_VIDEO_VIDEO_FRAME_WRITER_H_