|  | /* | 
|  | * Copyright (c) 2016, Alliance for Open Media. All rights reserved | 
|  | * | 
|  | * This source code is subject to the terms of the BSD 2 Clause License and | 
|  | * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License | 
|  | * was not distributed with this source code in the LICENSE file, you can | 
|  | * obtain it at www.aomedia.org/license/software. 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 www.aomedia.org/license/patent. | 
|  | */ | 
|  | #ifndef TEST_WEBM_VIDEO_SOURCE_H_ | 
|  | #define TEST_WEBM_VIDEO_SOURCE_H_ | 
|  | #include <cstdarg> | 
|  | #include <cstdio> | 
|  | #include <cstdlib> | 
|  | #include <new> | 
|  | #include <string> | 
|  | #include "../tools_common.h" | 
|  | #include "../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_(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_; | 
|  | FillFrame(); | 
|  | } | 
|  |  | 
|  | void FillFrame() { | 
|  | ASSERT_TRUE(aom_ctx_->file != NULL); | 
|  | const int status = webm_read_frame(webm_ctx_, &buf_, &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_, &buf_sz_); | 
|  | ASSERT_GE(status, 0) << "webm_read_frame failed"; | 
|  | ++frame_; | 
|  | 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 buf_sz_; } | 
|  | virtual unsigned int frame_number() const { return frame_; } | 
|  |  | 
|  | protected: | 
|  | std::string file_name_; | 
|  | AvxInputContext *aom_ctx_; | 
|  | WebmInputContext *webm_ctx_; | 
|  | uint8_t *buf_; | 
|  | size_t buf_sz_; | 
|  | unsigned int frame_; | 
|  | bool end_of_file_; | 
|  | }; | 
|  |  | 
|  | }  // namespace libaom_test | 
|  |  | 
|  | #endif  // TEST_WEBM_VIDEO_SOURCE_H_ |