Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1012)

Unified Diff: media/cast/sender/fake_video_encode_accelerator_factory.cc

Issue 868803007: [Cast] Refactor ExternalVideoEncoder for cleaner/simpler encapsulation. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add clarification comments and TODOs. Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « media/cast/sender/fake_video_encode_accelerator_factory.h ('k') | media/cast/sender/video_sender.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/cast/sender/fake_video_encode_accelerator_factory.cc
diff --git a/media/cast/sender/fake_video_encode_accelerator_factory.cc b/media/cast/sender/fake_video_encode_accelerator_factory.cc
new file mode 100644
index 0000000000000000000000000000000000000000..24eba4b07eea986e068ab2c458c8a43e7eb556cc
--- /dev/null
+++ b/media/cast/sender/fake_video_encode_accelerator_factory.cc
@@ -0,0 +1,81 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "media/cast/sender/fake_video_encode_accelerator_factory.h"
+
+#include "base/callback_helpers.h"
+
+namespace media {
+namespace cast {
+
+FakeVideoEncodeAcceleratorFactory::FakeVideoEncodeAcceleratorFactory(
+ const scoped_refptr<base::SingleThreadTaskRunner>& task_runner)
+ : task_runner_(task_runner),
+ will_init_succeed_(true),
+ auto_respond_(false),
+ vea_response_count_(0),
+ shm_response_count_(0),
+ last_response_vea_(nullptr),
+ last_response_shm_(nullptr) {}
+
+FakeVideoEncodeAcceleratorFactory::~FakeVideoEncodeAcceleratorFactory() {}
+
+void FakeVideoEncodeAcceleratorFactory::SetInitializationWillSucceed(
+ bool will_init_succeed) {
+ will_init_succeed_ = will_init_succeed;
+}
+
+void FakeVideoEncodeAcceleratorFactory::SetAutoRespond(bool auto_respond) {
+ auto_respond_ = auto_respond;
+ if (auto_respond_) {
+ if (!vea_response_callback_.is_null())
+ RespondWithVideoEncodeAccelerator();
+ if (!shm_response_callback_.is_null())
+ RespondWithSharedMemory();
+ }
+}
+
+void FakeVideoEncodeAcceleratorFactory::CreateVideoEncodeAccelerator(
+ const ReceiveVideoEncodeAcceleratorCallback& callback) {
+ DCHECK(!callback.is_null());
+ DCHECK(!next_response_vea_);
+
+ FakeVideoEncodeAccelerator* const vea =
+ new FakeVideoEncodeAccelerator(task_runner_);
+ vea->SetWillInitializationSucceed(will_init_succeed_);
+ next_response_vea_.reset(vea);
+ vea_response_callback_ = callback;
+ if (auto_respond_)
+ RespondWithVideoEncodeAccelerator();
+}
+
+void FakeVideoEncodeAcceleratorFactory::CreateSharedMemory(
+ size_t size, const ReceiveVideoEncodeMemoryCallback& callback) {
+ DCHECK(!callback.is_null());
+ DCHECK(!next_response_shm_);
+
+ next_response_shm_.reset(new base::SharedMemory());
+ CHECK(next_response_shm_->CreateAndMapAnonymous(size));
+ shm_response_callback_ = callback;
+ if (auto_respond_)
+ RespondWithSharedMemory();
+}
+
+void FakeVideoEncodeAcceleratorFactory::RespondWithVideoEncodeAccelerator() {
+ DCHECK(next_response_vea_.get());
+ last_response_vea_ = next_response_vea_.get();
+ ++vea_response_count_;
+ base::ResetAndReturn(&vea_response_callback_).Run(
+ task_runner_, next_response_vea_.Pass());
+}
+
+void FakeVideoEncodeAcceleratorFactory::RespondWithSharedMemory() {
+ DCHECK(next_response_shm_.get());
+ last_response_shm_ = next_response_shm_.get();
+ ++shm_response_count_;
+ base::ResetAndReturn(&shm_response_callback_).Run(next_response_shm_.Pass());
+}
+
+} // namespace cast
+} // namespace media
« no previous file with comments | « media/cast/sender/fake_video_encode_accelerator_factory.h ('k') | media/cast/sender/video_sender.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698