| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "media/filters/fake_video_decoder.h" | 5 #include "media/filters/fake_video_decoder.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/callback_helpers.h" | 8 #include "base/callback_helpers.h" |
| 9 #include "base/location.h" | 9 #include "base/location.h" |
| 10 #include "base/message_loop/message_loop_proxy.h" | 10 #include "base/message_loop/message_loop_proxy.h" |
| 11 #include "media/base/bind_to_current_loop.h" | 11 #include "media/base/bind_to_current_loop.h" |
| 12 #include "media/base/test_helpers.h" | 12 #include "media/base/test_helpers.h" |
| 13 | 13 |
| 14 namespace media { | 14 namespace media { |
| 15 | 15 |
| 16 FakeVideoDecoder::FakeVideoDecoder(int decoding_delay) | 16 FakeVideoDecoder::FakeVideoDecoder(int decoding_delay, |
| 17 bool supports_get_decode_output) |
| 17 : task_runner_(base::MessageLoopProxy::current()), | 18 : task_runner_(base::MessageLoopProxy::current()), |
| 18 weak_factory_(this), | 19 weak_factory_(this), |
| 19 decoding_delay_(decoding_delay), | 20 decoding_delay_(decoding_delay), |
| 21 supports_get_decode_output_(supports_get_decode_output), |
| 20 state_(UNINITIALIZED), | 22 state_(UNINITIALIZED), |
| 21 total_bytes_decoded_(0) { | 23 total_bytes_decoded_(0) { |
| 22 DCHECK_GE(decoding_delay, 0); | 24 DCHECK_GE(decoding_delay, 0); |
| 23 } | 25 } |
| 24 | 26 |
| 25 FakeVideoDecoder::~FakeVideoDecoder() { | 27 FakeVideoDecoder::~FakeVideoDecoder() { |
| 26 DCHECK_EQ(state_, UNINITIALIZED); | 28 DCHECK_EQ(state_, UNINITIALIZED); |
| 27 } | 29 } |
| 28 | 30 |
| 29 void FakeVideoDecoder::Initialize(const VideoDecoderConfig& config, | 31 void FakeVideoDecoder::Initialize(const VideoDecoderConfig& config, |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 96 DCHECK(task_runner_->BelongsToCurrentThread()); | 98 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 97 stop_cb_.SetCallback(BindToCurrentLoop(closure)); | 99 stop_cb_.SetCallback(BindToCurrentLoop(closure)); |
| 98 | 100 |
| 99 // Defer the stop if an init, a decode or a reset is pending. | 101 // Defer the stop if an init, a decode or a reset is pending. |
| 100 if (!init_cb_.IsNull() || !decode_cb_.IsNull() || !reset_cb_.IsNull()) | 102 if (!init_cb_.IsNull() || !decode_cb_.IsNull() || !reset_cb_.IsNull()) |
| 101 return; | 103 return; |
| 102 | 104 |
| 103 DoStop(); | 105 DoStop(); |
| 104 } | 106 } |
| 105 | 107 |
| 108 scoped_refptr<VideoFrame> FakeVideoDecoder::GetDecodeOutput() { |
| 109 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 110 if (!supports_get_decode_output_ || decoded_frames_.empty()) |
| 111 return NULL; |
| 112 scoped_refptr<VideoFrame> out = decoded_frames_.front(); |
| 113 decoded_frames_.pop_front(); |
| 114 return out; |
| 115 } |
| 116 |
| 106 void FakeVideoDecoder::HoldNextInit() { | 117 void FakeVideoDecoder::HoldNextInit() { |
| 107 DCHECK(task_runner_->BelongsToCurrentThread()); | 118 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 108 init_cb_.HoldCallback(); | 119 init_cb_.HoldCallback(); |
| 109 } | 120 } |
| 110 | 121 |
| 111 void FakeVideoDecoder::HoldNextRead() { | 122 void FakeVideoDecoder::HoldNextRead() { |
| 112 DCHECK(task_runner_->BelongsToCurrentThread()); | 123 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 113 decode_cb_.HoldCallback(); | 124 decode_cb_.HoldCallback(); |
| 114 } | 125 } |
| 115 | 126 |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 185 int buffer_size, | 196 int buffer_size, |
| 186 const DecodeCB& decode_cb, | 197 const DecodeCB& decode_cb, |
| 187 Status status, | 198 Status status, |
| 188 const scoped_refptr<VideoFrame>& video_frame) { | 199 const scoped_refptr<VideoFrame>& video_frame) { |
| 189 if (status == kOk || status == kNotEnoughData) | 200 if (status == kOk || status == kNotEnoughData) |
| 190 total_bytes_decoded_ += buffer_size; | 201 total_bytes_decoded_ += buffer_size; |
| 191 decode_cb.Run(status, video_frame); | 202 decode_cb.Run(status, video_frame); |
| 192 } | 203 } |
| 193 | 204 |
| 194 } // namespace media | 205 } // namespace media |
| OLD | NEW |