| 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 SERVICES_MEDIA_FRAMEWORK_MOJO_PUSH_PRODUCER_BASE_H_ |
| 6 #define SERVICES_MEDIA_FRAMEWORK_MOJO_PUSH_PRODUCER_BASE_H_ |
| 7 |
| 8 #include "base/single_thread_task_runner.h" |
| 9 #include "base/synchronization/lock.h" |
| 10 #include "base/task_runner.h" |
| 11 #include "mojo/services/media/common/interfaces/media_pipe.mojom.h" |
| 12 #include "mojo/services/media/common/interfaces/media_state.mojom.h" |
| 13 #include "services/media/framework/models/active_sink.h" |
| 14 #include "services/media/framework_mojo/mojo_allocator.h" |
| 15 |
| 16 namespace mojo { |
| 17 namespace media { |
| 18 |
| 19 // Abstract base class for push-mode producers. |
| 20 // TODO(dalesat): Merge producers once transport definitions are merged. |
| 21 class PushProducerBase : public ActiveSink { |
| 22 public: |
| 23 using StatusCallback = std::function<void(MediaState)>; |
| 24 |
| 25 PushProducerBase(); |
| 26 |
| 27 ~PushProducerBase() override; |
| 28 |
| 29 // Sets a callback for reporting status updates. |
| 30 void SetStatusCallback(const StatusCallback& callback); |
| 31 |
| 32 // ActiveSink implementation. |
| 33 PayloadAllocator* allocator() override; |
| 34 |
| 35 void SetDemandCallback(const DemandCallback& demand_callback) override; |
| 36 |
| 37 void Prime() override; |
| 38 |
| 39 Demand SupplyPacket(PacketPtr packet) override; |
| 40 |
| 41 protected: |
| 42 // Overridden in subclasses to verify that the producer is still connected. |
| 43 virtual bool IsConnected() = 0; |
| 44 |
| 45 // Overridden in subclasses to push a packet to the consumer/pipe. |
| 46 // packet_raw_ptr should be wrapped in a PacketPtr for proper lifetime |
| 47 // management. |
| 48 // TODO(dalesat): Don't use a raw pointer, if possible. |
| 49 virtual void PushPacketInternal( |
| 50 Packet* packet_raw_ptr, |
| 51 MediaPacketPtr media_packet) = 0; |
| 52 |
| 53 // Called by subclasses when a push completes. |
| 54 void PushCompleted(const PacketPtr& packet); |
| 55 |
| 56 // Called by subclasses when the connection to the consumer is lost. |
| 57 void OnConnectionLost(); |
| 58 |
| 59 // Allocates from the shared buffer. |
| 60 MojoAllocator mojo_allocator_; |
| 61 |
| 62 private: |
| 63 // Calls PushPacketInternal |
| 64 void PushPacket( |
| 65 Packet* packet_raw_ptr, |
| 66 MediaPacketPtr media_packet); |
| 67 |
| 68 // Sets the current state and calls the registered callback, if there is one. |
| 69 void SetState(MediaState state); |
| 70 |
| 71 // Creates a MediaPacket from a Packet. |
| 72 MediaPacketPtr CreateMediaPacket(const PacketPtr& packet); |
| 73 |
| 74 StatusCallback status_callback_; |
| 75 |
| 76 mutable base::Lock lock_; |
| 77 // THE FIELDS BELOW SHOULD ONLY BE ACCESSED WITH lock_ TAKEN. |
| 78 MediaState state_; |
| 79 bool end_of_stream_; |
| 80 DemandCallback demand_callback_; |
| 81 scoped_refptr<base::SingleThreadTaskRunner> task_runner_; |
| 82 // TODO(dalesat): Base this logic on presentation time or duration. |
| 83 uint32_t max_pushes_outstanding_; |
| 84 uint32_t current_pushes_outstanding_; |
| 85 // THE FIELDS ABOVE SHOULD ONLY BE ACCESSED WITH lock_ TAKEN. |
| 86 }; |
| 87 |
| 88 } // namespace media |
| 89 } // namespace mojo |
| 90 |
| 91 #endif // SERVICES_MEDIA_FRAMEWORK_MOJO_PUSH_PRODUCER_BASE_H_ |
| OLD | NEW |