blob: 9461a1f184e0c17ca2b1efb20babd391ec3edb46 [file] [log] [blame]
/*
* Copyright (c) 2012 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/main/interface/audio_coding_module.h"
#include "webrtc/common_types.h"
#include "webrtc/modules/audio_coding/main/source/acm_codec_database.h"
#include "webrtc/modules/audio_coding/main/source/acm_dtmf_detection.h"
#include "webrtc/modules/audio_coding/main/source/audio_coding_module_impl.h"
#include "webrtc/system_wrappers/interface/clock.h"
#include "webrtc/system_wrappers/interface/trace.h"
namespace webrtc {
// Create module
AudioCodingModule* AudioCodingModule::Create(const int32_t id) {
return new acm1::AudioCodingModuleImpl(id, Clock::GetRealTimeClock());
}
// Used for testing by inserting a simulated clock. ACM will not destroy the
// injected |clock| the client has to take care of that.
AudioCodingModule* AudioCodingModule::Create(const int32_t id,
Clock* clock) {
return new acm1::AudioCodingModuleImpl(id, clock);
}
// Destroy module
void AudioCodingModule::Destroy(AudioCodingModule* module) {
delete static_cast<acm1::AudioCodingModuleImpl*>(module);
}
// Get number of supported codecs
uint8_t AudioCodingModule::NumberOfCodecs() {
return static_cast<uint8_t>(acm1::ACMCodecDB::kNumCodecs);
}
// Get supported codec param with id
int32_t AudioCodingModule::Codec(uint8_t list_id,
CodecInst* codec) {
// Get the codec settings for the codec with the given list ID
return acm1::ACMCodecDB::Codec(list_id, codec);
}
// Get supported codec Param with name, frequency and number of channels.
int32_t AudioCodingModule::Codec(const char* payload_name,
CodecInst* codec, int sampling_freq_hz,
int channels) {
int codec_id;
// Get the id of the codec from the database.
codec_id = acm1::ACMCodecDB::CodecId(payload_name, sampling_freq_hz,
channels);
if (codec_id < 0) {
// We couldn't find a matching codec, set the parameters to unacceptable
// values and return.
codec->plname[0] = '\0';
codec->pltype = -1;
codec->pacsize = 0;
codec->rate = 0;
codec->plfreq = 0;
return -1;
}
// Get default codec settings.
acm1::ACMCodecDB::Codec(codec_id, codec);
// Keep the number of channels from the function call. For most codecs it
// will be the same value as in default codec settings, but not for all.
codec->channels = channels;
return 0;
}
// Get supported codec Index with name, frequency and number of channels.
int32_t AudioCodingModule::Codec(const char* payload_name,
int sampling_freq_hz, int channels) {
return acm1::ACMCodecDB::CodecId(payload_name, sampling_freq_hz, channels);
}
// Checks the validity of the parameters of the given codec
bool AudioCodingModule::IsCodecValid(const CodecInst& codec) {
int mirror_id;
int codec_number = acm1::ACMCodecDB::CodecNumber(&codec, &mirror_id);
if (codec_number < 0) {
WEBRTC_TRACE(webrtc::kTraceError, webrtc::kTraceAudioCoding, -1,
"Invalid codec settings.");
return false;
} else {
return true;
}
}
AudioCodingModule* AudioCodingModuleFactory::Create(int id) const {
return new acm1::AudioCodingModuleImpl(static_cast<int32_t>(id),
Clock::GetRealTimeClock());
}
AudioCodingModule* NewAudioCodingModuleFactory::Create(int id) const {
// TODO(minyue): return new AudioCodingModuleImpl (new version).
return NULL;
}
} // namespace webrtc