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

This reverts commit 6f5b0f920a
.
Reason for revert: Breaks internal project.
Original change's description:
> Remove rtc::Optional alias and api:optional target
>
> Update left-overs where old target still was used.
>
> Bug: webrtc:9078
> Change-Id: I2162c928091fc4ff1dea33a3f03adbe47207d206
> Reviewed-on: https://webrtc-review.googlesource.com/84740
> Commit-Queue: Danil Chapovalov <danilchap@webrtc.org>
> Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#23913}
TBR=danilchap@webrtc.org,kwiberg@webrtc.org
Change-Id: I95f5ec33520b823c3d0c9cb83d945d6a15355367
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: webrtc:9078
Reviewed-on: https://webrtc-review.googlesource.com/88140
Reviewed-by: Ilya Nikolaevskiy <ilnik@webrtc.org>
Commit-Queue: Ilya Nikolaevskiy <ilnik@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#23921}
105 lines
3.7 KiB
C++
105 lines
3.7 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 "absl/types/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 absl::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 absl::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.
|
|
absl::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 : absl::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 absl::optional<RTPHeader> NextHeader() const = 0;
|
|
};
|
|
|
|
// Wrapper class to impose a time limit on a NetEqInput object, typically
|
|
// another time limit than what the object itself provides. For example, an
|
|
// input taken from a file can be cut shorter by wrapping it in this class.
|
|
class TimeLimitedNetEqInput : public NetEqInput {
|
|
public:
|
|
TimeLimitedNetEqInput(std::unique_ptr<NetEqInput> input, int64_t duration_ms);
|
|
rtc::Optional<int64_t> NextPacketTime() const override;
|
|
rtc::Optional<int64_t> NextOutputEventTime() const override;
|
|
std::unique_ptr<PacketData> PopPacket() override;
|
|
void AdvanceOutputEvent() override;
|
|
bool ended() const override;
|
|
rtc::Optional<RTPHeader> NextHeader() const override;
|
|
|
|
private:
|
|
void MaybeSetEnded();
|
|
|
|
std::unique_ptr<NetEqInput> input_;
|
|
const rtc::Optional<int64_t> start_time_ms_;
|
|
const int64_t duration_ms_;
|
|
bool ended_ = false;
|
|
};
|
|
|
|
} // namespace test
|
|
} // namespace webrtc
|
|
#endif // MODULES_AUDIO_CODING_NETEQ_TOOLS_NETEQ_INPUT_H_
|