OLD | NEW |
---|---|
(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_ | |
OLD | NEW |