ReplayGain{Config,Global}: move to config/

This commit is contained in:
Max Kellermann 2021-12-03 23:04:39 +01:00
parent 95a155b10d
commit dda521a150
8 changed files with 26 additions and 62 deletions

View File

@ -281,6 +281,7 @@ sources = [
'src/command/CommandListBuilder.cxx', 'src/command/CommandListBuilder.cxx',
'src/config/PartitionConfig.cxx', 'src/config/PartitionConfig.cxx',
'src/config/PlayerConfig.cxx', 'src/config/PlayerConfig.cxx',
'src/config/ReplayGainConfig.cxx',
'src/Idle.cxx', 'src/Idle.cxx',
'src/IdleFlags.cxx', 'src/IdleFlags.cxx',
'src/decoder/Thread.cxx', 'src/decoder/Thread.cxx',
@ -336,7 +337,6 @@ sources = [
'src/queue/PlaylistEdit.cxx', 'src/queue/PlaylistEdit.cxx',
'src/queue/PlaylistTag.cxx', 'src/queue/PlaylistTag.cxx',
'src/queue/PlaylistState.cxx', 'src/queue/PlaylistState.cxx',
'src/ReplayGainGlobal.cxx',
'src/LocateUri.cxx', 'src/LocateUri.cxx',
'src/SongUpdate.cxx', 'src/SongUpdate.cxx',
'src/SongLoader.cxx', 'src/SongLoader.cxx',

View File

@ -1,29 +0,0 @@
/*
* Copyright 2003-2021 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#ifndef MPD_REPLAY_GAIN_GLOBAL_HXX
#define MPD_REPLAY_GAIN_GLOBAL_HXX
struct ConfigData;
struct ReplayGainConfig;
ReplayGainConfig
LoadReplayGainConfig(const ConfigData &config);
#endif

View File

@ -18,7 +18,7 @@
*/ */
#include "ReplayGainInfo.hxx" #include "ReplayGainInfo.hxx"
#include "ReplayGainConfig.hxx" #include "config/ReplayGainConfig.hxx"
#include <cmath> #include <cmath>

View File

@ -25,13 +25,13 @@
#include "util/RuntimeError.hxx" #include "util/RuntimeError.hxx"
#include "Log.hxx" #include "Log.hxx"
#include "MusicChunk.hxx" #include "MusicChunk.hxx"
#include "ReplayGainGlobal.hxx"
static constexpr static constexpr
size_t MIN_BUFFER_SIZE = std::max(CHUNK_SIZE * 32, size_t MIN_BUFFER_SIZE = std::max(CHUNK_SIZE * 32,
64 * KILOBYTE); 64 * KILOBYTE);
PlayerConfig::PlayerConfig(const ConfigData &config) PlayerConfig::PlayerConfig(const ConfigData &config)
:replay_gain(config)
{ {
size_t buffer_size = PlayerConfig::DEFAULT_BUFFER_SIZE; size_t buffer_size = PlayerConfig::DEFAULT_BUFFER_SIZE;
if (auto *param = config.GetParam(ConfigOption::AUDIO_BUFFER_SIZE)) { if (auto *param = config.GetParam(ConfigOption::AUDIO_BUFFER_SIZE)) {
@ -62,6 +62,4 @@ PlayerConfig::PlayerConfig(const ConfigData &config)
return ParseAudioFormat(s, true); return ParseAudioFormat(s, true);
}); });
replay_gain = LoadReplayGainConfig(config);
} }

View File

@ -17,9 +17,8 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/ */
#include "ReplayGainGlobal.hxx"
#include "ReplayGainConfig.hxx" #include "ReplayGainConfig.hxx"
#include "config/Data.hxx" #include "Data.hxx"
#include <cassert> #include <cassert>
#include <cmath> #include <cmath>
@ -42,25 +41,18 @@ ParsePreamp(const char *s)
return std::pow(10.0f, f / 20.0f); return std::pow(10.0f, f / 20.0f);
} }
ReplayGainConfig ReplayGainConfig::ReplayGainConfig(const ConfigData &config)
LoadReplayGainConfig(const ConfigData &config) :preamp(config.With(ConfigOption::REPLAYGAIN_PREAMP, [](const char *s){
return s != nullptr
? ParsePreamp(s)
: 1.0f;
})),
missing_preamp(config.With(ConfigOption::REPLAYGAIN_MISSING_PREAMP, [](const char *s){
return s != nullptr
? ParsePreamp(s)
: 1.0f;
})),
limit(config.GetBool(ConfigOption::REPLAYGAIN_LIMIT,
ReplayGainConfig::DEFAULT_LIMIT))
{ {
ReplayGainConfig replay_gain_config;
replay_gain_config.preamp = config.With(ConfigOption::REPLAYGAIN_PREAMP, [](const char *s){
return s != nullptr
? ParsePreamp(s)
: 1.0f;
});
replay_gain_config.missing_preamp = config.With(ConfigOption::REPLAYGAIN_MISSING_PREAMP, [](const char *s){
return s != nullptr
? ParsePreamp(s)
: 1.0f;
});
replay_gain_config.limit = config.GetBool(ConfigOption::REPLAYGAIN_LIMIT,
ReplayGainConfig::DEFAULT_LIMIT);
return replay_gain_config;
} }

View File

@ -17,8 +17,9 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/ */
#ifndef MPD_REPLAY_GAIN_CONFIG_HXX #pragma once
#define MPD_REPLAY_GAIN_CONFIG_HXX
struct ConfigData;
struct ReplayGainConfig { struct ReplayGainConfig {
static constexpr bool DEFAULT_LIMIT = true; static constexpr bool DEFAULT_LIMIT = true;
@ -28,6 +29,8 @@ struct ReplayGainConfig {
float missing_preamp = 1.0; float missing_preamp = 1.0;
bool limit = DEFAULT_LIMIT; bool limit = DEFAULT_LIMIT;
};
#endif ReplayGainConfig() = default;
explicit ReplayGainConfig(const ConfigData &config);
};

View File

@ -28,7 +28,7 @@
#include "thread/Cond.hxx" #include "thread/Cond.hxx"
#include "thread/Thread.hxx" #include "thread/Thread.hxx"
#include "Chrono.hxx" #include "Chrono.hxx"
#include "ReplayGainConfig.hxx" #include "config/ReplayGainConfig.hxx"
#include "ReplayGainMode.hxx" #include "ReplayGainMode.hxx"
#include <cassert> #include <cassert>

View File

@ -21,7 +21,7 @@
#include "filter/Filter.hxx" #include "filter/Filter.hxx"
#include "filter/Prepared.hxx" #include "filter/Prepared.hxx"
#include "ReplayGainInfo.hxx" #include "ReplayGainInfo.hxx"
#include "ReplayGainConfig.hxx" #include "config/ReplayGainConfig.hxx"
#include "mixer/MixerControl.hxx" #include "mixer/MixerControl.hxx"
#include "pcm/AudioFormat.hxx" #include "pcm/AudioFormat.hxx"
#include "pcm/Volume.hxx" #include "pcm/Volume.hxx"