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

Side by Side Diff: services/media/framework/models/active_sink.h

Issue 1678433002: Motown: Remove LPCM optimizations, fix prepare, add flush, add ActiveMultistreamSink model/stage (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Sync 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
1 // Copyright 2016 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef MOJO_MEDIA_MODELS_ACTIVE_SINK_H_ 5 #ifndef MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
6 #define MOJO_MEDIA_MODELS_ACTIVE_SINK_H_ 6 #define MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
7 7
8 #include <memory>
9
10 #include "services/media/framework/allocator.h"
11 #include "services/media/framework/models/demand.h" 8 #include "services/media/framework/models/demand.h"
9 #include "services/media/framework/models/part.h"
12 #include "services/media/framework/packet.h" 10 #include "services/media/framework/packet.h"
11 #include "services/media/framework/payload_allocator.h"
13 12
14 namespace mojo { 13 namespace mojo {
15 namespace media { 14 namespace media {
16 15
17 // Sink that consumes packets asynchronously. 16 // Sink that consumes packets asynchronously.
18 class ActiveSink { 17 class ActiveSink : public Part {
19 public: 18 public:
20 using DemandCallback = std::function<void(Demand demand)>; 19 using DemandCallback = std::function<void(Demand demand)>;
21 20
22 virtual ~ActiveSink() {} 21 ~ActiveSink() override {}
23 22
24 // Indicates whether the sink must allocate. 23 // An allocator that must be used for supplied packets or nullptr if there's
25 virtual bool must_allocate() const = 0; 24 // no such requirement.
26 25 virtual PayloadAllocator* allocator() = 0;
27 // The consumer's allocator. Can return nullptr, in which case the default
28 // allocator should be used.
29 virtual Allocator* allocator() = 0;
30 26
31 // Sets the callback that signals demand asynchronously. 27 // Sets the callback that signals demand asynchronously.
32 virtual void SetDemandCallback(DemandCallback demand_callback) = 0; 28 virtual void SetDemandCallback(const DemandCallback& demand_callback) = 0;
33 29
34 // Initiates demand. 30 // Initiates demand.
35 virtual void Prime() = 0; 31 virtual void Prime() = 0;
36 32
37 // Supplies a packet to the sink. 33 // Supplies a packet to the sink, returning the new demand for the input.
38 virtual Demand SupplyPacket(PacketPtr packet) = 0; 34 virtual Demand SupplyPacket(PacketPtr packet) = 0;
39 }; 35 };
40 36
41 typedef std::shared_ptr<ActiveSink> ActiveSinkPtr;
42
43 } // namespace media 37 } // namespace media
44 } // namespace mojo 38 } // namespace mojo
45 39
46 #endif // MOJO_MEDIA_MODELS_ACTIVE_SINK_H_ 40 #endif // MOJO_MEDIA_MODELS_ACTIVE_SINK_H_
OLDNEW
« no previous file with comments | « services/media/framework/models/active_multistream_sink.h ('k') | services/media/framework/models/active_source.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698