/* * Copyright (c) 2014 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 "api/audio_codecs/audio_encoder.h" #include "rtc_base/checks.h" #include "rtc_base/trace_event.h" namespace webrtc { ANAStats::ANAStats() = default; ANAStats::~ANAStats() = default; ANAStats::ANAStats(const ANAStats&) = default; AudioEncoder::EncodedInfo::EncodedInfo() = default; AudioEncoder::EncodedInfo::EncodedInfo(const EncodedInfo&) = default; AudioEncoder::EncodedInfo::EncodedInfo(EncodedInfo&&) = default; AudioEncoder::EncodedInfo::~EncodedInfo() = default; AudioEncoder::EncodedInfo& AudioEncoder::EncodedInfo::operator=( const EncodedInfo&) = default; AudioEncoder::EncodedInfo& AudioEncoder::EncodedInfo::operator=(EncodedInfo&&) = default; int AudioEncoder::RtpTimestampRateHz() const { return SampleRateHz(); } AudioEncoder::EncodedInfo AudioEncoder::Encode( uint32_t rtp_timestamp, rtc::ArrayView audio, rtc::Buffer* encoded) { TRACE_EVENT0("webrtc", "AudioEncoder::Encode"); RTC_CHECK_EQ(audio.size(), static_cast(NumChannels() * SampleRateHz() / 100)); const size_t old_size = encoded->size(); EncodedInfo info = EncodeImpl(rtp_timestamp, audio, encoded); RTC_CHECK_EQ(encoded->size() - old_size, info.encoded_bytes); return info; } bool AudioEncoder::SetFec(bool enable) { return !enable; } bool AudioEncoder::SetDtx(bool enable) { return !enable; } bool AudioEncoder::GetDtx() const { return false; } bool AudioEncoder::SetApplication(Application application) { return false; } void AudioEncoder::SetMaxPlaybackRate(int frequency_hz) {} void AudioEncoder::SetTargetBitrate(int target_bps) {} rtc::ArrayView> AudioEncoder::ReclaimContainedEncoders() { return nullptr; } bool AudioEncoder::EnableAudioNetworkAdaptor(const std::string& config_string, RtcEventLog* event_log) { return false; } void AudioEncoder::DisableAudioNetworkAdaptor() {} void AudioEncoder::OnReceivedUplinkPacketLossFraction( float uplink_packet_loss_fraction) {} void AudioEncoder::OnReceivedUplinkRecoverablePacketLossFraction( float uplink_recoverable_packet_loss_fraction) { RTC_NOTREACHED(); } void AudioEncoder::OnReceivedTargetAudioBitrate(int target_audio_bitrate_bps) { OnReceivedUplinkBandwidth(target_audio_bitrate_bps, absl::nullopt); } void AudioEncoder::OnReceivedUplinkBandwidth( int target_audio_bitrate_bps, absl::optional bwe_period_ms) {} void AudioEncoder::OnReceivedUplinkAllocation(BitrateAllocationUpdate update) { OnReceivedUplinkBandwidth(update.target_bitrate.bps(), update.bwe_period.ms()); } void AudioEncoder::OnReceivedRtt(int rtt_ms) {} void AudioEncoder::OnReceivedOverhead(size_t overhead_bytes_per_packet) {} void AudioEncoder::SetReceiverFrameLengthRange(int min_frame_length_ms, int max_frame_length_ms) {} ANAStats AudioEncoder::GetANAStats() const { return ANAStats(); } } // namespace webrtc