/* * 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. */ #include "webrtc/modules/audio_coding/neteq/tools/neteq_packet_source_input.h" #include #include #include "webrtc/modules/audio_coding/neteq/tools/rtc_event_log_source.h" #include "webrtc/modules/audio_coding/neteq/tools/rtp_file_source.h" #include "webrtc/rtc_base/checks.h" namespace webrtc { namespace test { NetEqPacketSourceInput::NetEqPacketSourceInput() : next_output_event_ms_(0) {} rtc::Optional NetEqPacketSourceInput::NextPacketTime() const { return packet_ ? rtc::Optional(static_cast(packet_->time_ms())) : rtc::Optional(); } rtc::Optional NetEqPacketSourceInput::NextHeader() const { return packet_ ? rtc::Optional(packet_->header()) : rtc::Optional(); } void NetEqPacketSourceInput::LoadNextPacket() { packet_ = source()->NextPacket(); } std::unique_ptr NetEqPacketSourceInput::PopPacket() { if (!packet_) { return std::unique_ptr(); } std::unique_ptr packet_data(new PacketData); packet_data->header = packet_->header(); if (packet_->payload_length_bytes() == 0 && packet_->virtual_payload_length_bytes() > 0) { // This is a header-only "dummy" packet. Set the payload to all zeros, with // length according to the virtual length. packet_data->payload.SetSize(packet_->virtual_payload_length_bytes()); std::fill_n(packet_data->payload.data(), packet_data->payload.size(), 0); } else { packet_data->payload.SetData(packet_->payload(), packet_->payload_length_bytes()); } packet_data->time_ms = packet_->time_ms(); LoadNextPacket(); return packet_data; } NetEqRtpDumpInput::NetEqRtpDumpInput(const std::string& file_name, const RtpHeaderExtensionMap& hdr_ext_map) : source_(RtpFileSource::Create(file_name)) { for (const auto& ext_pair : hdr_ext_map) { source_->RegisterRtpHeaderExtension(ext_pair.second, ext_pair.first); } LoadNextPacket(); } rtc::Optional NetEqRtpDumpInput::NextOutputEventTime() const { return next_output_event_ms_; } void NetEqRtpDumpInput::AdvanceOutputEvent() { if (next_output_event_ms_) { *next_output_event_ms_ += kOutputPeriodMs; } if (!NextPacketTime()) { next_output_event_ms_ = rtc::Optional(); } } PacketSource* NetEqRtpDumpInput::source() { return source_.get(); } NetEqEventLogInput::NetEqEventLogInput(const std::string& file_name, const RtpHeaderExtensionMap& hdr_ext_map) : source_(RtcEventLogSource::Create(file_name)) { for (const auto& ext_pair : hdr_ext_map) { source_->RegisterRtpHeaderExtension(ext_pair.second, ext_pair.first); } LoadNextPacket(); AdvanceOutputEvent(); } rtc::Optional NetEqEventLogInput::NextOutputEventTime() const { return rtc::Optional(next_output_event_ms_); } void NetEqEventLogInput::AdvanceOutputEvent() { next_output_event_ms_ = rtc::Optional(source_->NextAudioOutputEventMs()); if (*next_output_event_ms_ == std::numeric_limits::max()) { next_output_event_ms_ = rtc::Optional(); } } PacketSource* NetEqEventLogInput::source() { return source_.get(); } } // namespace test } // namespace webrtc