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

Unified Diff: services/media/framework/models/active_sink.h

Issue 1577953002: Motown in-proc streaming framework used to implement media services. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Sync, updates based on feedback, some functions declared const. Created 4 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
Index: services/media/framework/models/active_sink.h
diff --git a/services/media/framework/models/active_sink.h b/services/media/framework/models/active_sink.h
new file mode 100644
index 0000000000000000000000000000000000000000..d581bb9a8ddc57ac0f19588fdd9d6cd5a05fa5e4
--- /dev/null
+++ b/services/media/framework/models/active_sink.h
@@ -0,0 +1,46 @@
+// Copyright 2016 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 MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
+#define MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
+
+#include <memory>
+
+#include "services/media/framework/allocator.h"
+#include "services/media/framework/models/demand.h"
+#include "services/media/framework/packet.h"
+
+namespace mojo {
+namespace media {
+
+// Sink that consumes packets asynchronously.
jeffbrown 2016/02/02 05:35:47 In general it's a little unclear what subclasses m
dalesat 2016/02/02 21:46:39 Yes, we need to provide more guidance for source/s
+class ActiveSink {
+ public:
+ using DemandCallback = std::function<void(Demand demand)>;
jeffbrown 2016/02/02 05:35:47 Should this be defined next to Demand?
dalesat 2016/02/02 21:46:39 I don't think so. Its exact signature is a functio
+
+ virtual ~ActiveSink() {}
+
+ // Indicates whether the sink must allocate.
+ virtual bool must_allocate() const = 0;
jeffbrown 2016/02/02 05:35:47 Should be called MustAllocate because this method
dalesat 2016/02/02 21:46:39 In that case, I don't understand the rules. From G
+
+ // The consumer's allocator. Can return nullptr, in which case the default
+ // allocator should be used.
+ virtual Allocator* allocator() = 0;
+
+ // Registers a callback that signals demand asynchronously.
+ virtual void RegisterDemandCallback(DemandCallback demand_callback) = 0;
jeffbrown 2016/02/02 05:35:47 Can there only be one callback? If so, consider c
dalesat 2016/02/02 21:46:39 Done.
+
+ // Initiates demand.
+ virtual void Prime() = 0;
+
+ // Supplies a packet to the sink.
+ virtual Demand SupplyPacket(PacketPtr packet) = 0;
+};
+
+typedef std::shared_ptr<ActiveSink> ActiveSinkPtr;
jeffbrown 2016/02/02 05:35:47 These typedefs are making it very hard to understa
dalesat 2016/02/02 21:46:39 Yes, I've added a TODO elsewhere. I received feedb
+
+} // namespace media
+} // namespace mojo
+
+#endif // MOJO_MEDIA_MODELS_ACTIVE_SINK_H_

Powered by Google App Engine
This is Rietveld 408576698