// Copyright (c) 2017-2021, Mudita Sp. z.o.o. All rights reserved.
// For licensing, see https://github.com/mudita/MuditaOS/LICENSE.md
#include "AudioCommon.hpp"
#include "Profiles/Profile.hpp"
#include <Utils.hpp>
#include <sstream>
namespace audio
{
audio::RetCode GetDeviceError(AudioDevice::RetCode retCode)
{
if (retCode == AudioDevice::RetCode::Success) {
return RetCode::Success;
}
return RetCode::DeviceFailure;
}
const std::string str(RetCode retcode)
{
return utils::enumToString(retcode);
}
const std::string str(const PlaybackType &playbackType) noexcept
{
if (playbackType == PlaybackType::None) {
return "";
}
return utils::enumToString(playbackType);
}
const std::string str(const Setting &setting) noexcept
{
return utils::enumToString(setting);
}
const std::string dbPath(const sys::phone_modes::PhoneMode &phoneMode,
const Setting &setting,
const PlaybackType &playbackType,
const Profile::Type &profileType)
{
if (profileType == Profile::Type::Idle && playbackType == PlaybackType::None) {
return std::string();
}
constexpr auto separator = '/';
std::string path(audioDbPrefix);
path.append(utils::enumToString(phoneMode));
path.append(1, separator);
if (auto s = str(profileType); !s.empty()) {
path.append(s.append(1, separator));
}
if (auto s = str(playbackType); !s.empty()) {
path.append(s.append(1, separator));
}
if (auto s = str(setting); !s.empty()) {
path.append(s);
}
return path;
}
auto GetVolumeText(const audio::Volume &volume) -> std::string
{
return (static_cast<std::ostringstream &&>(std::ostringstream() << "Vol: " << std::to_string(volume))).str();
}
} // namespace audio