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

Unified Diff: media/mojo/services/demuxer_stream_provider_shim.h

Issue 684963003: Add support for external video renderers in mojo. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@mojo_config
Patch Set: More MSVC... Created 6 years, 1 month 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/mojo/services/BUILD.gn ('k') | media/mojo/services/demuxer_stream_provider_shim.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: media/mojo/services/demuxer_stream_provider_shim.h
diff --git a/media/mojo/services/demuxer_stream_provider_shim.h b/media/mojo/services/demuxer_stream_provider_shim.h
new file mode 100644
index 0000000000000000000000000000000000000000..e614e11c95fb6618e8a55668bcd3c48679020bd3
--- /dev/null
+++ b/media/mojo/services/demuxer_stream_provider_shim.h
@@ -0,0 +1,55 @@
+// Copyright 2014 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.
+
+#ifndef MEDIA_MOJO_SERVICES_DEMUXER_STREAM_PROVIDER_SHIM_H_
+#define MEDIA_MOJO_SERVICES_DEMUXER_STREAM_PROVIDER_SHIM_H_
+
+#include "base/callback.h"
+#include "base/memory/scoped_vector.h"
+#include "base/memory/weak_ptr.h"
+#include "media/base/demuxer_stream_provider.h"
+#include "media/mojo/services/mojo_demuxer_stream_adapter.h"
+
+namespace media {
+
+// DemuxerStreamProvider shim for mojo::DemuxerStreams.
+class DemuxerStreamProviderShim : public DemuxerStreamProvider {
+ public:
+ // Constructs the shim; at least a single audio or video stream must be
+ // provided. |demuxer_ready_cb| will be called once the streams have been
+ // initialized. Calling any method before then is an error.
+ DemuxerStreamProviderShim(mojo::DemuxerStreamPtr audio,
+ mojo::DemuxerStreamPtr video,
+ const base::Closure& demuxer_ready_cb);
+ ~DemuxerStreamProviderShim() override;
+
+ // DemuxerStreamProvider interface.
+ DemuxerStream* GetStream(DemuxerStream::Type type) override;
+ Liveness GetLiveness() const override;
+
+ private:
+ // Called as each mojo::DemuxerStream becomes ready. Once all streams are
+ // ready it will fire the |demuxer_ready_cb_| provided during construction.
+ void OnStreamReady();
+
+ // Stored copy the ready callback provided during construction; cleared once
+ // all streams are ready.
+ base::Closure demuxer_ready_cb_;
+
+ // Scoped container for demuxer stream adapters which interface with the
+ // mojo level demuxer streams. |streams_ready_| tracks how many streams are
+ // ready and is used by OnStreamReady() to know when |demuxer_ready_cb_|
+ // should be fired.
+ ScopedVector<MojoDemuxerStreamAdapter> streams_;
+ size_t streams_ready_;
+
+ // WeakPtrFactorys must always be the last member variable.
+ base::WeakPtrFactory<DemuxerStreamProviderShim> weak_factory_;
+
+ DISALLOW_COPY_AND_ASSIGN(DemuxerStreamProviderShim);
+};
+
+} // namespace media
+
+#endif // MEDIA_MOJO_SERVICES_DEMUXER_STREAM_PROVIDER_SHIM_H_
« no previous file with comments | « media/mojo/services/BUILD.gn ('k') | media/mojo/services/demuxer_stream_provider_shim.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698