| /* |
| * Copyright (c) 2021, Alliance for Open Media. All rights reserved |
| * |
| * This source code is subject to the terms of the BSD 3-Clause Clear License |
| * and the Alliance for Open Media Patent License 1.0. If the BSD 3-Clause Clear |
| * License was not distributed with this source code in the LICENSE file, you |
| * can obtain it at aomedia.org/license/software-license/bsd-3-c-c/. If the |
| * Alliance for Open Media Patent License 1.0 was not distributed with this |
| * source code in the PATENTS file, you can obtain it at |
| * aomedia.org/license/patent-license/. |
| */ |
| #ifndef AOM_TEST_WEBM_VIDEO_SOURCE_H_ |
| #define AOM_TEST_WEBM_VIDEO_SOURCE_H_ |
| #include <cstdarg> |
| #include <cstdio> |
| #include <cstdlib> |
| #include <new> |
| #include <string> |
| #include "common/tools_common.h" |
| #include "common/webmdec.h" |
| #include "test/video_source.h" |
| |
| namespace libaom_test { |
| |
| // This class extends VideoSource to allow parsing of WebM files, |
| // so that we can do actual file decodes. |
| class WebMVideoSource : public CompressedVideoSource { |
| public: |
| explicit WebMVideoSource(const std::string &file_name) |
| : file_name_(file_name), aom_ctx_(new AvxInputContext()), |
| webm_ctx_(new WebmInputContext()), buf_(NULL), buf_sz_(0), frame_sz_(0), |
| frame_number_(0), end_of_file_(false) {} |
| |
| virtual ~WebMVideoSource() { |
| if (aom_ctx_->file != NULL) fclose(aom_ctx_->file); |
| webm_free(webm_ctx_); |
| delete aom_ctx_; |
| delete webm_ctx_; |
| } |
| |
| virtual void Init() {} |
| |
| virtual void Begin() { |
| aom_ctx_->file = OpenTestDataFile(file_name_); |
| ASSERT_TRUE(aom_ctx_->file != NULL) |
| << "Input file open failed. Filename: " << file_name_; |
| |
| ASSERT_EQ(file_is_webm(webm_ctx_, aom_ctx_), 1) << "file is not WebM"; |
| |
| FillFrame(); |
| } |
| |
| virtual void Next() { |
| ++frame_number_; |
| FillFrame(); |
| } |
| |
| void FillFrame() { |
| ASSERT_TRUE(aom_ctx_->file != NULL); |
| const int status = webm_read_frame(webm_ctx_, &buf_, &frame_sz_, &buf_sz_); |
| ASSERT_GE(status, 0) << "webm_read_frame failed"; |
| if (status == 1) { |
| end_of_file_ = true; |
| } |
| } |
| |
| void SeekToNextKeyFrame() { |
| ASSERT_TRUE(aom_ctx_->file != NULL); |
| do { |
| const int status = |
| webm_read_frame(webm_ctx_, &buf_, &frame_sz_, &buf_sz_); |
| ASSERT_GE(status, 0) << "webm_read_frame failed"; |
| ++frame_number_; |
| if (status == 1) { |
| end_of_file_ = true; |
| } |
| } while (!webm_ctx_->is_key_frame && !end_of_file_); |
| } |
| |
| virtual const uint8_t *cxdata() const { return end_of_file_ ? NULL : buf_; } |
| virtual size_t frame_size() const { return frame_sz_; } |
| virtual unsigned int frame_number() const { return frame_number_; } |
| |
| protected: |
| std::string file_name_; |
| AvxInputContext *aom_ctx_; |
| WebmInputContext *webm_ctx_; |
| uint8_t *buf_; // Owned by webm_ctx_ and freed when webm_ctx_ is freed. |
| size_t buf_sz_; |
| size_t frame_sz_; |
| unsigned int frame_number_; |
| bool end_of_file_; |
| }; |
| |
| } // namespace libaom_test |
| |
| #endif // AOM_TEST_WEBM_VIDEO_SOURCE_H_ |