config/Option: convert to strictly-typed enum
This commit is contained in:
		| @@ -39,7 +39,7 @@ getOutputAudioFormat(AudioFormat inAudioFormat) | ||||
|  | ||||
| void initAudioConfig(void) | ||||
| { | ||||
| 	const struct config_param *param = config_get_param(CONF_AUDIO_OUTPUT_FORMAT); | ||||
| 	const struct config_param *param = config_get_param(ConfigOption::AUDIO_OUTPUT_FORMAT); | ||||
|  | ||||
| 	if (param == nullptr) | ||||
| 		return; | ||||
|   | ||||
| @@ -103,9 +103,9 @@ listen_systemd_activation(Error &error_r) | ||||
| bool | ||||
| listen_global_init(EventLoop &loop, Partition &partition, Error &error) | ||||
| { | ||||
| 	int port = config_get_positive(CONF_PORT, DEFAULT_PORT); | ||||
| 	int port = config_get_positive(ConfigOption::PORT, DEFAULT_PORT); | ||||
| 	const struct config_param *param = | ||||
| 		config_get_param(CONF_BIND_TO_ADDRESS); | ||||
| 		config_get_param(ConfigOption::BIND_TO_ADDRESS); | ||||
|  | ||||
| 	listen_socket = new ClientListener(loop, partition); | ||||
|  | ||||
|   | ||||
| @@ -139,14 +139,14 @@ log_init(bool verbose, bool use_stdout, Error &error) | ||||
|  | ||||
| 	if (verbose) | ||||
| 		SetLogThreshold(LogLevel::DEBUG); | ||||
| 	else if ((param = config_get_param(CONF_LOG_LEVEL)) != nullptr) | ||||
| 	else if ((param = config_get_param(ConfigOption::LOG_LEVEL)) != nullptr) | ||||
| 		SetLogThreshold(parse_log_level(param->value.c_str(), | ||||
| 						param->line)); | ||||
|  | ||||
| 	if (use_stdout) { | ||||
| 		return true; | ||||
| 	} else { | ||||
| 		param = config_get_param(CONF_LOG_FILE); | ||||
| 		param = config_get_param(ConfigOption::LOG_FILE); | ||||
| 		if (param == nullptr) { | ||||
| #ifdef HAVE_SYSLOG | ||||
| 			/* no configuration: default to syslog (if | ||||
| @@ -164,7 +164,7 @@ log_init(bool verbose, bool use_stdout, Error &error) | ||||
| 			return true; | ||||
| #endif | ||||
| 		} else { | ||||
| 			out_path = config_get_path(CONF_LOG_FILE, error); | ||||
| 			out_path = config_get_path(ConfigOption::LOG_FILE, error); | ||||
| 			return !out_path.IsNull() && | ||||
| 				log_init_file(param->line, error); | ||||
| 		} | ||||
|   | ||||
							
								
								
									
										28
									
								
								src/Main.cxx
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								src/Main.cxx
									
									
									
									
									
								
							| @@ -141,12 +141,12 @@ static StateFile *state_file; | ||||
| static bool | ||||
| glue_daemonize_init(const struct options *options, Error &error) | ||||
| { | ||||
| 	auto pid_file = config_get_path(CONF_PID_FILE, error); | ||||
| 	auto pid_file = config_get_path(ConfigOption::PID_FILE, error); | ||||
| 	if (pid_file.IsNull() && error.IsDefined()) | ||||
| 		return false; | ||||
|  | ||||
| 	daemonize_init(config_get_string(CONF_USER, nullptr), | ||||
| 		       config_get_string(CONF_GROUP, nullptr), | ||||
| 	daemonize_init(config_get_string(ConfigOption::USER, nullptr), | ||||
| 		       config_get_string(ConfigOption::GROUP, nullptr), | ||||
| 		       std::move(pid_file)); | ||||
|  | ||||
| 	if (options->kill) | ||||
| @@ -160,7 +160,7 @@ glue_daemonize_init(const struct options *options, Error &error) | ||||
| static bool | ||||
| glue_mapper_init(Error &error) | ||||
| { | ||||
| 	auto playlist_dir = config_get_path(CONF_PLAYLIST_DIR, error); | ||||
| 	auto playlist_dir = config_get_path(ConfigOption::PLAYLIST_DIR, error); | ||||
| 	if (playlist_dir.IsNull() && error.IsDefined()) | ||||
| 		return false; | ||||
|  | ||||
| @@ -255,7 +255,7 @@ glue_sticker_init(void) | ||||
| { | ||||
| #ifdef ENABLE_SQLITE | ||||
| 	Error error; | ||||
| 	auto sticker_file = config_get_path(CONF_STICKER_FILE, error); | ||||
| 	auto sticker_file = config_get_path(ConfigOption::STICKER_FILE, error); | ||||
| 	if (sticker_file.IsNull()) { | ||||
| 		if (error.IsDefined()) | ||||
| 			FatalError(error); | ||||
| @@ -270,7 +270,7 @@ glue_sticker_init(void) | ||||
| static bool | ||||
| glue_state_file_init(Error &error) | ||||
| { | ||||
| 	auto path_fs = config_get_path(CONF_STATE_FILE, error); | ||||
| 	auto path_fs = config_get_path(ConfigOption::STATE_FILE, error); | ||||
| 	if (path_fs.IsNull()) { | ||||
| 		if (error.IsDefined()) | ||||
| 			return false; | ||||
| @@ -286,7 +286,8 @@ glue_state_file_init(Error &error) | ||||
| #endif | ||||
| 	} | ||||
|  | ||||
| 	unsigned interval = config_get_unsigned(CONF_STATE_FILE_INTERVAL, | ||||
| 	const unsigned interval = | ||||
| 		config_get_unsigned(ConfigOption::STATE_FILE_INTERVAL, | ||||
| 				    StateFile::DEFAULT_INTERVAL); | ||||
|  | ||||
| 	state_file = new StateFile(std::move(path_fs), interval, | ||||
| @@ -324,7 +325,7 @@ initialize_decoder_and_player(void) | ||||
| 	const struct config_param *param; | ||||
|  | ||||
| 	size_t buffer_size; | ||||
| 	param = config_get_param(CONF_AUDIO_BUFFER_SIZE); | ||||
| 	param = config_get_param(ConfigOption::AUDIO_BUFFER_SIZE); | ||||
| 	if (param != nullptr) { | ||||
| 		char *test; | ||||
| 		long tmp = strtol(param->value.c_str(), &test, 10); | ||||
| @@ -345,7 +346,7 @@ initialize_decoder_and_player(void) | ||||
| 				 (unsigned long)buffer_size); | ||||
|  | ||||
| 	float perc; | ||||
| 	param = config_get_param(CONF_BUFFER_BEFORE_PLAY); | ||||
| 	param = config_get_param(ConfigOption::BUFFER_BEFORE_PLAY); | ||||
| 	if (param != nullptr) { | ||||
| 		char *test; | ||||
| 		perc = strtod(param->value.c_str(), &test); | ||||
| @@ -363,7 +364,7 @@ initialize_decoder_and_player(void) | ||||
| 		buffered_before_play = buffered_chunks; | ||||
|  | ||||
| 	const unsigned max_length = | ||||
| 		config_get_positive(CONF_MAX_PLAYLIST_LENGTH, | ||||
| 		config_get_positive(ConfigOption::MAX_PLAYLIST_LENGTH, | ||||
| 				    DEFAULT_PLAYLIST_MAX_LENGTH); | ||||
|  | ||||
| 	instance->partition = new Partition(*instance, | ||||
| @@ -503,7 +504,8 @@ int mpd_main(int argc, char *argv[]) | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
| 	const unsigned max_clients = config_get_positive(CONF_MAX_CONN, 10); | ||||
| 	const unsigned max_clients = | ||||
| 		config_get_positive(ConfigOption::MAX_CONN, 10); | ||||
| 	instance->client_list = new ClientList(max_clients); | ||||
|  | ||||
| 	initialize_decoder_and_player(); | ||||
| @@ -630,14 +632,14 @@ static int mpd_main_after_fork(struct options options) | ||||
| 	instance->partition->outputs.SetReplayGainMode(replay_gain_get_real_mode(instance->partition->playlist.queue.random)); | ||||
|  | ||||
| #ifdef ENABLE_DATABASE | ||||
| 	if (config_get_bool(CONF_AUTO_UPDATE, false)) { | ||||
| 	if (config_get_bool(ConfigOption::AUTO_UPDATE, false)) { | ||||
| #ifdef ENABLE_INOTIFY | ||||
| 		if (instance->storage != nullptr && | ||||
| 		    instance->update != nullptr) | ||||
| 			mpd_inotify_init(*instance->event_loop, | ||||
| 					 *instance->storage, | ||||
| 					 *instance->update, | ||||
| 					 config_get_unsigned(CONF_AUTO_UPDATE_DEPTH, | ||||
| 					 config_get_unsigned(ConfigOption::AUTO_UPDATE_DEPTH, | ||||
| 							     INT_MAX)); | ||||
| #else | ||||
| 		FormatWarning(main_domain, | ||||
|   | ||||
| @@ -92,7 +92,7 @@ void initPermissions(void) | ||||
| 	permission_default = PERMISSION_READ | PERMISSION_ADD | | ||||
| 	    PERMISSION_CONTROL | PERMISSION_ADMIN; | ||||
|  | ||||
| 	param = config_get_param(CONF_PASSWORD); | ||||
| 	param = config_get_param(ConfigOption::PASSWORD); | ||||
|  | ||||
| 	if (param) { | ||||
| 		permission_default = 0; | ||||
| @@ -118,7 +118,7 @@ void initPermissions(void) | ||||
| 		} while ((param = param->next) != nullptr); | ||||
| 	} | ||||
|  | ||||
| 	param = config_get_param(CONF_DEFAULT_PERMS); | ||||
| 	param = config_get_param(ConfigOption::DEFAULT_PERMS); | ||||
|  | ||||
| 	if (param) | ||||
| 		permission_default = parsePermissions(param->value.c_str()); | ||||
|   | ||||
| @@ -53,11 +53,12 @@ bool playlist_saveAbsolutePaths = DEFAULT_PLAYLIST_SAVE_ABSOLUTE_PATHS; | ||||
| void | ||||
| spl_global_init(void) | ||||
| { | ||||
| 	playlist_max_length = config_get_positive(CONF_MAX_PLAYLIST_LENGTH, | ||||
| 	playlist_max_length = | ||||
| 		config_get_positive(ConfigOption::MAX_PLAYLIST_LENGTH, | ||||
| 				    DEFAULT_PLAYLIST_MAX_LENGTH); | ||||
|  | ||||
| 	playlist_saveAbsolutePaths = | ||||
| 		config_get_bool(CONF_SAVE_ABSOLUTE_PATHS, | ||||
| 		config_get_bool(ConfigOption::SAVE_ABSOLUTE_PATHS, | ||||
| 				DEFAULT_PLAYLIST_SAVE_ABSOLUTE_PATHS); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -81,7 +81,8 @@ replay_gain_set_mode_string(const char *p) | ||||
|  | ||||
| void replay_gain_global_init(void) | ||||
| { | ||||
| 	const struct config_param *param = config_get_param(CONF_REPLAYGAIN); | ||||
| 	const struct config_param *param = | ||||
| 		config_get_param(ConfigOption::REPLAYGAIN); | ||||
|  | ||||
| 	if (param != nullptr && | ||||
| 	    !replay_gain_set_mode_string(param->value.c_str())) { | ||||
| @@ -89,7 +90,7 @@ void replay_gain_global_init(void) | ||||
| 				 param->value.c_str(), param->line); | ||||
| 	} | ||||
|  | ||||
| 	param = config_get_param(CONF_REPLAYGAIN_PREAMP); | ||||
| 	param = config_get_param(ConfigOption::REPLAYGAIN_PREAMP); | ||||
|  | ||||
| 	if (param) { | ||||
| 		char *test; | ||||
| @@ -110,7 +111,7 @@ void replay_gain_global_init(void) | ||||
| 		replay_gain_preamp = pow(10, f / 20.0); | ||||
| 	} | ||||
|  | ||||
| 	param = config_get_param(CONF_REPLAYGAIN_MISSING_PREAMP); | ||||
| 	param = config_get_param(ConfigOption::REPLAYGAIN_MISSING_PREAMP); | ||||
|  | ||||
| 	if (param) { | ||||
| 		char *test; | ||||
| @@ -131,7 +132,8 @@ void replay_gain_global_init(void) | ||||
| 		replay_gain_missing_preamp = pow(10, f / 20.0); | ||||
| 	} | ||||
|  | ||||
| 	replay_gain_limit = config_get_bool(CONF_REPLAYGAIN_LIMIT, DEFAULT_REPLAYGAIN_LIMIT); | ||||
| 	replay_gain_limit = config_get_bool(ConfigOption::REPLAYGAIN_LIMIT, | ||||
| 					    DEFAULT_REPLAYGAIN_LIMIT); | ||||
| } | ||||
|  | ||||
| ReplayGainMode | ||||
|   | ||||
| @@ -31,15 +31,15 @@ size_t client_max_output_buffer_size; | ||||
|  | ||||
| void client_manager_init(void) | ||||
| { | ||||
| 	client_timeout = config_get_positive(CONF_CONN_TIMEOUT, | ||||
| 	client_timeout = config_get_positive(ConfigOption::CONN_TIMEOUT, | ||||
| 					     CLIENT_TIMEOUT_DEFAULT); | ||||
| 	client_max_command_list_size = | ||||
| 		config_get_positive(CONF_MAX_COMMAND_LIST_SIZE, | ||||
| 		config_get_positive(ConfigOption::MAX_COMMAND_LIST_SIZE, | ||||
| 				    CLIENT_MAX_COMMAND_LIST_DEFAULT / 1024) | ||||
| 		* 1024; | ||||
|  | ||||
| 	client_max_output_buffer_size = | ||||
| 		config_get_positive(CONF_MAX_OUTPUT_BUFFER_SIZE, | ||||
| 		config_get_positive(ConfigOption::MAX_OUTPUT_BUFFER_SIZE, | ||||
| 				    CLIENT_MAX_OUTPUT_BUFFER_SIZE_DEFAULT / 1024) | ||||
| 		* 1024; | ||||
| } | ||||
|   | ||||
| @@ -175,7 +175,7 @@ ReadConfigFile(ConfigData &config_data, FILE *fp, Error &error) | ||||
| 		   "repeatable" flag */ | ||||
|  | ||||
| 		const ConfigOption o = ParseConfigOptionName(name); | ||||
| 		if (o == CONF_MAX) { | ||||
| 		if (o == ConfigOption::MAX) { | ||||
| 			error.Format(config_file_domain, | ||||
| 				     "unrecognized parameter in config file at " | ||||
| 				     "line %i: %s\n", count, name); | ||||
|   | ||||
| @@ -22,68 +22,78 @@ | ||||
|  | ||||
| #include "Compiler.h" | ||||
|  | ||||
| enum ConfigOption { | ||||
| 	CONF_MUSIC_DIR, | ||||
| 	CONF_PLAYLIST_DIR, | ||||
| 	CONF_FOLLOW_INSIDE_SYMLINKS, | ||||
| 	CONF_FOLLOW_OUTSIDE_SYMLINKS, | ||||
| 	CONF_DB_FILE, | ||||
| 	CONF_STICKER_FILE, | ||||
| 	CONF_LOG_FILE, | ||||
| 	CONF_PID_FILE, | ||||
| 	CONF_STATE_FILE, | ||||
| 	CONF_STATE_FILE_INTERVAL, | ||||
| 	CONF_RESTORE_PAUSED, | ||||
| 	CONF_USER, | ||||
| 	CONF_GROUP, | ||||
| 	CONF_BIND_TO_ADDRESS, | ||||
| 	CONF_PORT, | ||||
| 	CONF_LOG_LEVEL, | ||||
| 	CONF_ZEROCONF_NAME, | ||||
| 	CONF_ZEROCONF_ENABLED, | ||||
| 	CONF_PASSWORD, | ||||
| 	CONF_DEFAULT_PERMS, | ||||
| 	CONF_AUDIO_OUTPUT, | ||||
| 	CONF_AUDIO_OUTPUT_FORMAT, | ||||
| 	CONF_MIXER_TYPE, | ||||
| 	CONF_REPLAYGAIN, | ||||
| 	CONF_REPLAYGAIN_PREAMP, | ||||
| 	CONF_REPLAYGAIN_MISSING_PREAMP, | ||||
| 	CONF_REPLAYGAIN_LIMIT, | ||||
| 	CONF_VOLUME_NORMALIZATION, | ||||
| 	CONF_SAMPLERATE_CONVERTER, | ||||
| 	CONF_AUDIO_BUFFER_SIZE, | ||||
| 	CONF_BUFFER_BEFORE_PLAY, | ||||
| 	CONF_HTTP_PROXY_HOST, | ||||
| 	CONF_HTTP_PROXY_PORT, | ||||
| 	CONF_HTTP_PROXY_USER, | ||||
| 	CONF_HTTP_PROXY_PASSWORD, | ||||
| 	CONF_CONN_TIMEOUT, | ||||
| 	CONF_MAX_CONN, | ||||
| 	CONF_MAX_PLAYLIST_LENGTH, | ||||
| 	CONF_MAX_COMMAND_LIST_SIZE, | ||||
| 	CONF_MAX_OUTPUT_BUFFER_SIZE, | ||||
| 	CONF_FS_CHARSET, | ||||
| 	CONF_ID3V1_ENCODING, | ||||
| 	CONF_METADATA_TO_USE, | ||||
| 	CONF_SAVE_ABSOLUTE_PATHS, | ||||
| 	CONF_DECODER, | ||||
| 	CONF_INPUT, | ||||
| 	CONF_GAPLESS_MP3_PLAYBACK, | ||||
| 	CONF_PLAYLIST_PLUGIN, | ||||
| 	CONF_AUTO_UPDATE, | ||||
| 	CONF_AUTO_UPDATE_DEPTH, | ||||
| 	CONF_DESPOTIFY_USER, | ||||
| 	CONF_DESPOTIFY_PASSWORD, | ||||
| 	CONF_DESPOTIFY_HIGH_BITRATE, | ||||
| 	CONF_AUDIO_FILTER, | ||||
| 	CONF_DATABASE, | ||||
| 	CONF_NEIGHBORS, | ||||
| 	CONF_MAX | ||||
| #if defined(WIN32) && CLANG_OR_GCC_VERSION(4,7) | ||||
| /* "INPUT" is declared by winuser.h */ | ||||
| #pragma GCC diagnostic push | ||||
| #pragma GCC diagnostic ignored "-Wshadow" | ||||
| #endif | ||||
|  | ||||
| enum class ConfigOption { | ||||
| 	MUSIC_DIR, | ||||
| 	PLAYLIST_DIR, | ||||
| 	FOLLOW_INSIDE_SYMLINKS, | ||||
| 	FOLLOW_OUTSIDE_SYMLINKS, | ||||
| 	DB_FILE, | ||||
| 	STICKER_FILE, | ||||
| 	LOG_FILE, | ||||
| 	PID_FILE, | ||||
| 	STATE_FILE, | ||||
| 	STATE_FILE_INTERVAL, | ||||
| 	RESTORE_PAUSED, | ||||
| 	USER, | ||||
| 	GROUP, | ||||
| 	BIND_TO_ADDRESS, | ||||
| 	PORT, | ||||
| 	LOG_LEVEL, | ||||
| 	ZEROCONF_NAME, | ||||
| 	ZEROCONF_ENABLED, | ||||
| 	PASSWORD, | ||||
| 	DEFAULT_PERMS, | ||||
| 	AUDIO_OUTPUT, | ||||
| 	AUDIO_OUTPUT_FORMAT, | ||||
| 	MIXER_TYPE, | ||||
| 	REPLAYGAIN, | ||||
| 	REPLAYGAIN_PREAMP, | ||||
| 	REPLAYGAIN_MISSING_PREAMP, | ||||
| 	REPLAYGAIN_LIMIT, | ||||
| 	VOLUME_NORMALIZATION, | ||||
| 	SAMPLERATE_CONVERTER, | ||||
| 	AUDIO_BUFFER_SIZE, | ||||
| 	BUFFER_BEFORE_PLAY, | ||||
| 	HTTP_PROXY_HOST, | ||||
| 	HTTP_PROXY_PORT, | ||||
| 	HTTP_PROXY_USER, | ||||
| 	HTTP_PROXY_PASSWORD, | ||||
| 	CONN_TIMEOUT, | ||||
| 	MAX_CONN, | ||||
| 	MAX_PLAYLIST_LENGTH, | ||||
| 	MAX_COMMAND_LIST_SIZE, | ||||
| 	MAX_OUTPUT_BUFFER_SIZE, | ||||
| 	FS_CHARSET, | ||||
| 	ID3V1_ENCODING, | ||||
| 	METADATA_TO_USE, | ||||
| 	SAVE_ABSOLUTE_PATHS, | ||||
| 	DECODER, | ||||
| 	INPUT, | ||||
| 	GAPLESS_MP3_PLAYBACK, | ||||
| 	PLAYLIST_PLUGIN, | ||||
| 	AUTO_UPDATE, | ||||
| 	AUTO_UPDATE_DEPTH, | ||||
| 	DESPOTIFY_USER, | ||||
| 	DESPOTIFY_PASSWORD, | ||||
| 	DESPOTIFY_HIGH_BITRATE, | ||||
| 	AUDIO_FILTER, | ||||
| 	DATABASE, | ||||
| 	NEIGHBORS, | ||||
| 	MAX | ||||
| }; | ||||
|  | ||||
| #if defined(WIN32) && CLANG_OR_GCC_VERSION(4,7) | ||||
| #pragma GCC diagnostic pop | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|  * @return #CONF_MAX if not found | ||||
|  * @return #ConfigOption::MAX if not found | ||||
|  */ | ||||
| gcc_pure | ||||
| enum ConfigOption | ||||
|   | ||||
| @@ -70,7 +70,7 @@ GetHome(Error &error) | ||||
| static AllocatedPath | ||||
| GetConfiguredHome(Error &error) | ||||
| { | ||||
| 	const char *user = config_get_string(CONF_USER, nullptr); | ||||
| 	const char *user = config_get_string(ConfigOption::USER, nullptr); | ||||
| 	return user != nullptr | ||||
| 		? GetHome(user, error) | ||||
| 		: GetHome(error); | ||||
|   | ||||
| @@ -84,7 +84,7 @@ const ConfigTemplate config_templates[] = { | ||||
|  | ||||
| static constexpr unsigned n_config_templates = ARRAY_SIZE(config_templates); | ||||
|  | ||||
| static_assert(n_config_templates == unsigned(CONF_MAX), | ||||
| static_assert(n_config_templates == unsigned(ConfigOption::MAX), | ||||
| 	      "Wrong number of config_templates"); | ||||
|  | ||||
| ConfigOption | ||||
| @@ -94,5 +94,5 @@ ParseConfigOptionName(const char *name) | ||||
| 		if (strcmp(config_templates[i].name, name) == 0) | ||||
| 			return ConfigOption(i); | ||||
|  | ||||
| 	return CONF_MAX; | ||||
| 	return ConfigOption::MAX; | ||||
| } | ||||
|   | ||||
| @@ -27,7 +27,7 @@ | ||||
| struct config_param; | ||||
|  | ||||
| struct ConfigData { | ||||
| 	std::array<config_param *, std::size_t(CONF_MAX)> params; | ||||
| 	std::array<config_param *, std::size_t(ConfigOption::MAX)> params; | ||||
|  | ||||
| 	void Clear(); | ||||
| }; | ||||
|   | ||||
| @@ -32,8 +32,8 @@ Database * | ||||
| CreateConfiguredDatabase(EventLoop &loop, DatabaseListener &listener, | ||||
| 			 Error &error) | ||||
| { | ||||
| 	const struct config_param *param = config_get_param(CONF_DATABASE); | ||||
| 	const struct config_param *path = config_get_param(CONF_DB_FILE); | ||||
| 	const auto *param = config_get_param(ConfigOption::DATABASE); | ||||
| 	const auto *path = config_get_param(ConfigOption::DB_FILE); | ||||
|  | ||||
| 	if (param != nullptr && path != nullptr) { | ||||
| 		error.Format(config_domain, | ||||
|   | ||||
| @@ -57,11 +57,11 @@ UpdateWalk::UpdateWalk(EventLoop &_loop, DatabaseListener &_listener, | ||||
| { | ||||
| #ifndef WIN32 | ||||
| 	follow_inside_symlinks = | ||||
| 		config_get_bool(CONF_FOLLOW_INSIDE_SYMLINKS, | ||||
| 		config_get_bool(ConfigOption::FOLLOW_INSIDE_SYMLINKS, | ||||
| 				DEFAULT_FOLLOW_INSIDE_SYMLINKS); | ||||
|  | ||||
| 	follow_outside_symlinks = | ||||
| 		config_get_bool(CONF_FOLLOW_OUTSIDE_SYMLINKS, | ||||
| 		config_get_bool(ConfigOption::FOLLOW_OUTSIDE_SYMLINKS, | ||||
| 				DEFAULT_FOLLOW_OUTSIDE_SYMLINKS); | ||||
| #endif | ||||
| } | ||||
|   | ||||
| @@ -132,7 +132,8 @@ void decoder_plugin_init_all(void) | ||||
| 	for (unsigned i = 0; decoder_plugins[i] != nullptr; ++i) { | ||||
| 		const DecoderPlugin &plugin = *decoder_plugins[i]; | ||||
| 		const struct config_param *param = | ||||
| 			config_find_block(CONF_DECODER, "plugin", plugin.name); | ||||
| 			config_find_block(ConfigOption::DECODER, "plugin", | ||||
| 					  plugin.name); | ||||
|  | ||||
| 		if (param == nullptr) | ||||
| 			param = ∅ | ||||
|   | ||||
| @@ -109,7 +109,7 @@ mad_fixed_to_24_buffer(int32_t *dest, const struct mad_synth *synth, | ||||
| static bool | ||||
| mp3_plugin_init(gcc_unused const config_param ¶m) | ||||
| { | ||||
| 	gapless_playback = config_get_bool(CONF_GAPLESS_MP3_PLAYBACK, | ||||
| 	gapless_playback = config_get_bool(ConfigOption::GAPLESS_MP3_PLAYBACK, | ||||
| 					   DEFAULT_GAPLESS_MP3_PLAYBACK); | ||||
| 	return true; | ||||
| } | ||||
|   | ||||
| @@ -35,7 +35,8 @@ static bool | ||||
| filter_chain_append_new(Filter &chain, const char *template_name, Error &error) | ||||
| { | ||||
| 	const struct config_param *cfg = | ||||
| 		config_find_block(CONF_AUDIO_FILTER, "name", template_name); | ||||
| 		config_find_block(ConfigOption::AUDIO_FILTER, "name", | ||||
| 				  template_name); | ||||
| 	if (cfg == nullptr) { | ||||
| 		error.Format(config_domain, | ||||
| 			     "filter template not found: %s", | ||||
|   | ||||
| @@ -35,7 +35,7 @@ ConfigureFS(Error &error) | ||||
| #ifdef HAVE_FS_CHARSET | ||||
| 	const char *charset = nullptr; | ||||
|  | ||||
| 	charset = config_get_string(CONF_FS_CHARSET, nullptr); | ||||
| 	charset = config_get_string(ConfigOption::FS_CHARSET, nullptr); | ||||
| 	if (charset == nullptr) { | ||||
| #ifdef WIN32 | ||||
| 		/* Glib claims that file system encoding is always utf-8 | ||||
|   | ||||
| @@ -43,7 +43,8 @@ input_stream_global_init(Error &error) | ||||
| 		assert(plugin->open != nullptr); | ||||
|  | ||||
| 		const struct config_param *param = | ||||
| 			config_find_block(CONF_INPUT, "plugin", plugin->name); | ||||
| 			config_find_block(ConfigOption::INPUT, "plugin", | ||||
| 					  plugin->name); | ||||
| 		if (param == nullptr) { | ||||
| 			param = ∅ | ||||
| 		} else if (!param->GetBlockValue("enabled", true)) | ||||
|   | ||||
| @@ -564,10 +564,10 @@ input_curl_init(const config_param ¶m, Error &error) | ||||
|  | ||||
| 	if (proxy == nullptr) { | ||||
| 		/* deprecated proxy configuration */ | ||||
| 		proxy = config_get_string(CONF_HTTP_PROXY_HOST, nullptr); | ||||
| 		proxy_port = config_get_positive(CONF_HTTP_PROXY_PORT, 0); | ||||
| 		proxy_user = config_get_string(CONF_HTTP_PROXY_USER, nullptr); | ||||
| 		proxy_password = config_get_string(CONF_HTTP_PROXY_PASSWORD, | ||||
| 		proxy = config_get_string(ConfigOption::HTTP_PROXY_HOST, nullptr); | ||||
| 		proxy_port = config_get_positive(ConfigOption::HTTP_PROXY_PORT, 0); | ||||
| 		proxy_user = config_get_string(ConfigOption::HTTP_PROXY_USER, nullptr); | ||||
| 		proxy_password = config_get_string(ConfigOption::HTTP_PROXY_PASSWORD, | ||||
| 						   ""); | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -124,9 +124,9 @@ mpd_despotify_get_session() | ||||
| 		return g_session; | ||||
|  | ||||
| 	const char *const user = | ||||
| 		config_get_string(CONF_DESPOTIFY_USER, nullptr); | ||||
| 		config_get_string(ConfigOption::DESPOTIFY_USER, nullptr); | ||||
| 	const char *const passwd = | ||||
| 		config_get_string(CONF_DESPOTIFY_PASSWORD, nullptr); | ||||
| 		config_get_string(ConfigOption::DESPOTIFY_PASSWORD, nullptr); | ||||
|  | ||||
| 	if (user == nullptr || passwd == nullptr) { | ||||
| 		LogDebug(despotify_domain, | ||||
| @@ -140,7 +140,7 @@ mpd_despotify_get_session() | ||||
| 	} | ||||
|  | ||||
| 	const bool high_bitrate = | ||||
| 		config_get_bool(CONF_DESPOTIFY_HIGH_BITRATE, true); | ||||
| 		config_get_bool(ConfigOption::DESPOTIFY_HIGH_BITRATE, true); | ||||
| 	g_session = despotify_init_client(callback, nullptr, | ||||
| 					  high_bitrate, true); | ||||
| 	if (!g_session) { | ||||
|   | ||||
| @@ -59,7 +59,7 @@ CreateNeighborExplorer(EventLoop &loop, NeighborListener &listener, | ||||
| bool | ||||
| NeighborGlue::Init(EventLoop &loop, NeighborListener &listener, Error &error) | ||||
| { | ||||
| 	for (const config_param *param = config_get_param(CONF_NEIGHBORS); | ||||
| 	for (const auto *param = config_get_param(ConfigOption::NEIGHBORS); | ||||
| 	     param != nullptr; param = param->next) { | ||||
| 		NeighborExplorer *explorer = | ||||
| 			CreateNeighborExplorer(loop, listener, *param, error); | ||||
|   | ||||
| @@ -108,7 +108,7 @@ audio_output_mixer_type(const config_param ¶m) | ||||
|  | ||||
| 	/* fall back to the global "mixer_type" setting (also | ||||
| 	   deprecated) */ | ||||
| 	return mixer_type_parse(config_get_string(CONF_MIXER_TYPE, | ||||
| 	return mixer_type_parse(config_get_string(ConfigOption::MIXER_TYPE, | ||||
| 						  "hardware")); | ||||
| } | ||||
|  | ||||
| @@ -191,7 +191,7 @@ AudioOutput::Configure(const config_param ¶m, Error &error) | ||||
|  | ||||
| 	/* create the normalization filter (if configured) */ | ||||
|  | ||||
| 	if (config_get_bool(CONF_VOLUME_NORMALIZATION, false)) { | ||||
| 	if (config_get_bool(ConfigOption::VOLUME_NORMALIZATION, false)) { | ||||
| 		Filter *normalize_filter = | ||||
| 			filter_new(&normalize_filter_plugin, config_param(), | ||||
| 				   IgnoreError()); | ||||
|   | ||||
| @@ -74,7 +74,7 @@ LoadOutput(EventLoop &event_loop, MixerListener &mixer_listener, | ||||
| void | ||||
| MultipleOutputs::Configure(EventLoop &event_loop, PlayerControl &pc) | ||||
| { | ||||
| 	for (const config_param *param = config_get_param(CONF_AUDIO_OUTPUT); | ||||
| 	for (const auto *param = config_get_param(ConfigOption::AUDIO_OUTPUT); | ||||
| 	     param != nullptr; param = param->next) { | ||||
| 		auto output = LoadOutput(event_loop, mixer_listener, | ||||
| 					 pc, *param); | ||||
|   | ||||
| @@ -53,7 +53,7 @@ bool | ||||
| pcm_resampler_global_init(Error &error) | ||||
| { | ||||
| 	const char *converter = | ||||
| 		config_get_string(CONF_SAMPLERATE_CONVERTER, ""); | ||||
| 		config_get_string(ConfigOption::SAMPLERATE_CONVERTER, ""); | ||||
|  | ||||
| 	if (strcmp(converter, "internal") == 0) | ||||
| 		return true; | ||||
|   | ||||
| @@ -81,9 +81,9 @@ playlist_list_global_init(void) | ||||
|  | ||||
| 	for (unsigned i = 0; playlist_plugins[i] != nullptr; ++i) { | ||||
| 		const struct playlist_plugin *plugin = playlist_plugins[i]; | ||||
| 		const struct config_param *param = | ||||
| 			config_find_block(CONF_PLAYLIST_PLUGIN, "name", | ||||
| 					  plugin->name); | ||||
| 		const auto *param = | ||||
| 			config_find_block(ConfigOption::PLAYLIST_PLUGIN, | ||||
| 					  "name", plugin->name); | ||||
| 		if (param == nullptr) | ||||
| 			param = ∅ | ||||
| 		else if (!param->GetBlockValue("enabled", true)) | ||||
|   | ||||
| @@ -195,7 +195,7 @@ playlist_state_restore(const char *line, TextFile &file, | ||||
| 			current = 0; | ||||
|  | ||||
| 		if (state == PlayerState::PLAY && | ||||
| 		    config_get_bool(CONF_RESTORE_PAUSED, false)) | ||||
| 		    config_get_bool(ConfigOption::RESTORE_PAUSED, false)) | ||||
| 			/* the user doesn't want MPD to auto-start | ||||
| 			   playback after startup; fall back to | ||||
| 			   "pause" */ | ||||
|   | ||||
| @@ -44,7 +44,7 @@ CreateConfiguredStorageUri(EventLoop &event_loop, const char *uri, | ||||
| static AllocatedPath | ||||
| GetConfiguredMusicDirectory(Error &error) | ||||
| { | ||||
| 	AllocatedPath path = config_get_path(CONF_MUSIC_DIR, error); | ||||
| 	AllocatedPath path = config_get_path(ConfigOption::MUSIC_DIR, error); | ||||
| 	if (path.IsNull() && !error.IsDefined()) | ||||
| 		path = GetUserMusicDir(); | ||||
|  | ||||
| @@ -68,7 +68,7 @@ CreateConfiguredStorage(EventLoop &event_loop, Error &error) | ||||
| { | ||||
| 	assert(!error.IsDefined()); | ||||
|  | ||||
| 	auto uri = config_get_string(CONF_MUSIC_DIR, nullptr); | ||||
| 	auto uri = config_get_string(ConfigOption::MUSIC_DIR, nullptr); | ||||
| 	if (uri != nullptr && uri_has_scheme(uri)) | ||||
| 		return CreateConfiguredStorageUri(event_loop, uri, error); | ||||
|  | ||||
| @@ -78,5 +78,5 @@ CreateConfiguredStorage(EventLoop &event_loop, Error &error) | ||||
| bool | ||||
| IsStorageConfigured() | ||||
| { | ||||
| 	return config_get_string(CONF_MUSIC_DIR, nullptr) != nullptr; | ||||
| 	return config_get_string(ConfigOption::MUSIC_DIR, nullptr) != nullptr; | ||||
| } | ||||
|   | ||||
| @@ -35,7 +35,8 @@ | ||||
| void | ||||
| TagLoadConfig() | ||||
| { | ||||
| 	const char *value = config_get_string(CONF_METADATA_TO_USE, nullptr); | ||||
| 	const char *value = config_get_string(ConfigOption::METADATA_TO_USE, | ||||
| 					      nullptr); | ||||
| 	if (value == nullptr) | ||||
| 		return; | ||||
|  | ||||
|   | ||||
| @@ -99,7 +99,8 @@ import_id3_string(bool is_id3v1, const id3_ucs4_t *ucs4) | ||||
| 	/* use encoding field here? */ | ||||
| 	const char *encoding; | ||||
| 	if (is_id3v1 && | ||||
| 	    (encoding = config_get_string(CONF_ID3V1_ENCODING, nullptr)) != nullptr) { | ||||
| 	    (encoding = config_get_string(ConfigOption::ID3V1_ENCODING, | ||||
| 					  nullptr)) != nullptr) { | ||||
| 		id3_latin1_t *isostr = id3_ucs4_latin1duplicate(ucs4); | ||||
| 		if (gcc_unlikely(isostr == nullptr)) | ||||
| 			return nullptr; | ||||
|   | ||||
| @@ -44,7 +44,7 @@ ZeroconfInit(gcc_unused EventLoop &loop) | ||||
| { | ||||
| 	const char *serviceName; | ||||
|  | ||||
| 	zeroconfEnabled = config_get_bool(CONF_ZEROCONF_ENABLED, | ||||
| 	zeroconfEnabled = config_get_bool(ConfigOption::ZEROCONF_ENABLED, | ||||
| 					  DEFAULT_ZEROCONF_ENABLED); | ||||
| 	if (!zeroconfEnabled) | ||||
| 		return; | ||||
| @@ -56,7 +56,8 @@ ZeroconfInit(gcc_unused EventLoop &loop) | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	serviceName = config_get_string(CONF_ZEROCONF_NAME, SERVICE_NAME); | ||||
| 	serviceName = config_get_string(ConfigOption::ZEROCONF_NAME, | ||||
| 					SERVICE_NAME); | ||||
|  | ||||
| #ifdef HAVE_AVAHI | ||||
| 	AvahiInit(loop, serviceName); | ||||
|   | ||||
| @@ -120,7 +120,7 @@ main(int argc, char **argv) | ||||
|  | ||||
| 	/* do it */ | ||||
|  | ||||
| 	const struct config_param *path = config_get_param(CONF_DB_FILE); | ||||
| 	const auto *path = config_get_param(ConfigOption::DB_FILE); | ||||
| 	config_param param("database", path != nullptr ? path->line : -1); | ||||
| 	if (path != nullptr) | ||||
| 		param.AddBlockParam("path", path->value.c_str(), path->line); | ||||
|   | ||||
| @@ -46,7 +46,7 @@ int main(int argc, char **argv) | ||||
| 	} | ||||
|  | ||||
| 	ConfigOption option = ParseConfigOptionName(name); | ||||
| 	const char *value = option != CONF_MAX | ||||
| 	const char *value = option != ConfigOption::MAX | ||||
| 		? config_get_string(option, nullptr) | ||||
| 		: nullptr; | ||||
| 	int ret; | ||||
|   | ||||
| @@ -51,7 +51,7 @@ static Filter * | ||||
| load_filter(const char *name) | ||||
| { | ||||
| 	const config_param *param = | ||||
| 		config_find_block(CONF_AUDIO_FILTER, "name", name); | ||||
| 		config_find_block(ConfigOption::AUDIO_FILTER, "name", name); | ||||
| 	if (param == NULL) { | ||||
| 		fprintf(stderr, "No such configured filter: %s\n", name); | ||||
| 		return nullptr; | ||||
|   | ||||
| @@ -62,7 +62,7 @@ static AudioOutput * | ||||
| load_audio_output(EventLoop &event_loop, const char *name) | ||||
| { | ||||
| 	const config_param *param = | ||||
| 		config_find_block(CONF_AUDIO_OUTPUT, "name", name); | ||||
| 		config_find_block(ConfigOption::AUDIO_OUTPUT, "name", name); | ||||
| 	if (param == NULL) { | ||||
| 		fprintf(stderr, "No such configured audio output: %s\n", name); | ||||
| 		return nullptr; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Max Kellermann
					Max Kellermann