/* * Copyright (c) 2017 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/g711/audio_decoder_g711.h" #include #include #include "absl/strings/match.h" #include "modules/audio_coding/codecs/g711/audio_decoder_pcm.h" #include "rtc_base/numerics/safe_conversions.h" namespace webrtc { absl::optional AudioDecoderG711::SdpToConfig( const SdpAudioFormat& format) { const bool is_pcmu = absl::EqualsIgnoreCase(format.name, "PCMU"); const bool is_pcma = absl::EqualsIgnoreCase(format.name, "PCMA"); if (format.clockrate_hz == 8000 && format.num_channels >= 1 && (is_pcmu || is_pcma)) { Config config; config.type = is_pcmu ? Config::Type::kPcmU : Config::Type::kPcmA; config.num_channels = rtc::dchecked_cast(format.num_channels); if (!config.IsOk()) { RTC_DCHECK_NOTREACHED(); return absl::nullopt; } return config; } else { return absl::nullopt; } } void AudioDecoderG711::AppendSupportedDecoders( std::vector* specs) { for (const char* type : {"PCMU", "PCMA"}) { specs->push_back({{type, 8000, 1}, {8000, 1, 64000}}); } } std::unique_ptr AudioDecoderG711::MakeAudioDecoder( const Config& config, absl::optional /*codec_pair_id*/, const FieldTrialsView* field_trials) { if (!config.IsOk()) { RTC_DCHECK_NOTREACHED(); return nullptr; } switch (config.type) { case Config::Type::kPcmU: return std::make_unique(config.num_channels); case Config::Type::kPcmA: return std::make_unique(config.num_channels); default: RTC_DCHECK_NOTREACHED(); return nullptr; } } } // namespace webrtc