mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-13 22:00:47 +01:00

Bug: webrtc:9147 Change-Id: I61ec7bc5299201e25e1efc503b73b84d5be3ebbf Reviewed-on: https://webrtc-review.googlesource.com/71740 Commit-Queue: Minyue Li <minyue@webrtc.org> Reviewed-by: Björn Terelius <terelius@webrtc.org> Reviewed-by: Henrik Lundin <henrik.lundin@webrtc.org> Cr-Commit-Position: refs/heads/master@{#23151}
83 lines
2.9 KiB
C++
83 lines
2.9 KiB
C++
/*
|
|
* 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 MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_
|
|
#define MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_
|
|
|
|
#include <algorithm>
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include "api/optional.h"
|
|
#include "common_types.h" // NOLINT(build/include)
|
|
#include "modules/audio_coding/neteq/tools/packet.h"
|
|
#include "modules/audio_coding/neteq/tools/packet_source.h"
|
|
#include "rtc_base/buffer.h"
|
|
|
|
namespace webrtc {
|
|
namespace test {
|
|
|
|
// Interface class for input to the NetEqTest class.
|
|
class NetEqInput {
|
|
public:
|
|
struct PacketData {
|
|
std::string ToString() const;
|
|
|
|
RTPHeader header;
|
|
rtc::Buffer payload;
|
|
int64_t 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 ? std::min(*a, *b) : a;
|
|
}
|
|
return b ? b : rtc::nullopt;
|
|
}
|
|
|
|
// Returns the next packet to be inserted into NetEq. The packet following the
|
|
// returned one is pre-fetched in the NetEqInput object, such that future
|
|
// calls to NextPacketTime() or NextHeader() will return information from that
|
|
// packet.
|
|
virtual std::unique_ptr<PacketData> PopPacket() = 0;
|
|
|
|
// 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. An implementation must
|
|
// eventually return true from this method, or the test will end up in an
|
|
// infinite loop.
|
|
virtual bool ended() const = 0;
|
|
|
|
// Returns the RTP header for the next packet, i.e., the packet that will be
|
|
// delivered next by PopPacket().
|
|
virtual rtc::Optional<RTPHeader> NextHeader() const = 0;
|
|
};
|
|
|
|
} // namespace test
|
|
} // namespace webrtc
|
|
#endif // MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_
|