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

Side by Side 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, 10 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
6 #define MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
7
8 #include <memory>
9
10 #include "services/media/framework/allocator.h"
11 #include "services/media/framework/models/demand.h"
12 #include "services/media/framework/packet.h"
13
14 namespace mojo {
15 namespace media {
16
17 // 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
18 class ActiveSink {
19 public:
20 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
21
22 virtual ~ActiveSink() {}
23
24 // Indicates whether the sink must allocate.
25 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
26
27 // The consumer's allocator. Can return nullptr, in which case the default
28 // allocator should be used.
29 virtual Allocator* allocator() = 0;
30
31 // Registers a callback that signals demand asynchronously.
32 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.
33
34 // Initiates demand.
35 virtual void Prime() = 0;
36
37 // Supplies a packet to the sink.
38 virtual Demand SupplyPacket(PacketPtr packet) = 0;
39 };
40
41 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
42
43 } // namespace media
44 } // namespace mojo
45
46 #endif // MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698