Chromium Code Reviews| Index: webrtc/modules/audio_coding/neteq/tools/neteq_input.h |
| diff --git a/webrtc/modules/audio_coding/neteq/tools/neteq_input.h b/webrtc/modules/audio_coding/neteq/tools/neteq_input.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..3f7c1c7f3df24221c88d3ff939d1a8ed0736de3b |
| --- /dev/null |
| +++ b/webrtc/modules/audio_coding/neteq/tools/neteq_input.h |
| @@ -0,0 +1,75 @@ |
| +/* |
| + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. |
| + * |
| + * Use of this source code is governed by a BSD-style license |
| + * that can be found in the LICENSE file in the root of the source |
| + * tree. An additional intellectual property rights grant can be found |
| + * in the file PATENTS. All contributing project authors may |
| + * be found in the AUTHORS file in the root of the source tree. |
| + */ |
| + |
| +#ifndef WEBRTC_MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_ |
| +#define WEBRTC_MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_ |
| + |
| +#include <algorithm> |
| +#include <memory> |
| + |
| +#include "webrtc/base/buffer.h" |
| +#include "webrtc/base/optional.h" |
| +#include "webrtc/modules/audio_coding/neteq/tools/packet.h" |
| +#include "webrtc/modules/audio_coding/neteq/tools/packet_source.h" |
| +#include "webrtc/modules/include/module_common_types.h" |
| + |
| +namespace webrtc { |
| +namespace test { |
| + |
| +// Interface class for input to the NetEqTest class. |
| +class NetEqInput { |
| + public: |
| + struct PacketData { |
| + WebRtcRTPHeader header; |
| + rtc::Buffer payload; |
| + double time_ms; |
| + }; |
| + |
| + virtual ~NetEqInput() = default; |
| + |
| + // Returns at what time (in ms) NetEq::InsertPacket should be called next, or |
| + // empty if the source is out of packets. |
| + virtual rtc::Optional<int64_t> NextPacketTime() const = 0; |
| + |
| + // Returns at what time (in ms) NetEq::GetAudio should be called next, or |
| + // empty if no more output events are available. |
| + virtual rtc::Optional<int64_t> NextOutputEventTime() const = 0; |
| + |
| + // Returns the time (in ms) for the next event from either NextPacketTime() |
| + // or NextOutputEventTime(), or empty if both are out of events. |
| + rtc::Optional<int64_t> NextEventTime() const { |
| + const auto a = NextPacketTime(); |
| + const auto b = NextOutputEventTime(); |
| + // Return the minimum of non-empty |a| and |b|, or empty if both are empty. |
| + if (a) { |
| + return b ? rtc::Optional<int64_t>(std::min(*a, *b)) : a; |
| + } |
| + return b ? b : rtc::Optional<int64_t>(); |
| + } |
| + |
| + // Returns the next packet to be inserted into NetEq. |
| + virtual std::unique_ptr<PacketData> GetPacket() = 0; |
|
ivoc
2016/06/14 16:39:56
Does this advance to the next packet? It's not ver
hlundin-webrtc
2016/06/17 10:30:08
It does advance to the next packet. I changed to P
|
| + |
| + // Move to the next output event. This will make NextOutputEventTime() return |
| + // a new value (potentially the same if several output events share the same |
| + // time). |
| + virtual void AdvanceOutputEvent() = 0; |
| + |
| + // Returns true if the source has come to an end. |
| + virtual bool ended() const = 0; |
| + |
| + // Returns the RTP header for the next packet, i.e., the packet that will be |
| + // delivered next by GetPacket(). |
| + virtual rtc::Optional<RTPHeader> NextHeader() const = 0; |
| +}; |
| + |
| +} // namespace test |
| +} // namespace webrtc |
| +#endif // WEBRTC_MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_ |