blob: f5ffbba6cad051086ae9c67de14686661ff15113 [file] [log] [blame]
/*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#define LOG_TAG "APM::AudioPolicyEngine/VolumeGroup"
//#define LOG_NDEBUG 0
#include "VolumeGroup.h"
#include <media/TypeConverter.h>
#include <utils/String8.h>
#include <cstdint>
#include <string>
#include <log/log.h>
namespace android {
//
// VolumeGroup implementation
//
VolumeGroup::VolumeGroup(const std::string &name, int indexMin, int indexMax) :
mName(name), mId(static_cast<volume_group_t>(HandleGenerator<uint32_t>::getNextHandle())),
mGroupVolumeCurves(VolumeCurves(indexMin, indexMax))
{
}
// Used for introspection, e.g. JAVA
AttributesVector VolumeGroup::getSupportedAttributes() const
{
AttributesVector supportedAttributes = {};
for (auto &aa : mGroupVolumeCurves.getAttributes()) {
aa.source = AUDIO_SOURCE_INVALID;
supportedAttributes.push_back(aa);
}
return supportedAttributes;
}
void VolumeGroup::dump(String8 *dst, int spaces) const
{
dst->appendFormat("\n%*s-%s (id: %d)\n", spaces, "", mName.c_str(), mId);
mGroupVolumeCurves.dump(dst, spaces + 2, true);
mGroupVolumeCurves.dump(dst, spaces + 2, false);
dst->appendFormat("\n");
}
void VolumeGroup::add(const sp<VolumeCurve> &curve)
{
mGroupVolumeCurves.add(curve);
}
void VolumeGroup::addSupportedAttributes(const audio_attributes_t &attr)
{
mGroupVolumeCurves.addAttributes(attr);
}
void VolumeGroup::addSupportedStream(audio_stream_type_t stream)
{
mGroupVolumeCurves.addStreamType(stream);
}
//
// VolumeGroupMap implementation
//
void VolumeGroupMap::dump(String8 *dst, int spaces) const
{
dst->appendFormat("\n%*sVolume Groups dump:", spaces, "");
for (const auto &iter : *this) {
iter.second->dump(dst, spaces + 2);
}
}
} // namespace android