From 72070f292b98ee8b38217b43dc046b047bcccd8e Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Wed, 30 Jan 2013 18:54:17 +0100 Subject: [PATCH] ConfigFile: add struct ConfigData --- src/ConfigData.hxx | 18 ++++++++++++++++++ src/ConfigFile.cxx | 17 ++++++++--------- 2 files changed, 26 insertions(+), 9 deletions(-) diff --git a/src/ConfigData.hxx b/src/ConfigData.hxx index d156cef18..98b74635f 100644 --- a/src/ConfigData.hxx +++ b/src/ConfigData.hxx @@ -20,11 +20,19 @@ #ifndef MPD_CONFIG_DATA_HXX #define MPD_CONFIG_DATA_HXX +#include "ConfigOption.hxx" #include "gerror.h" #include "gcc.h" +#ifdef __cplusplus +#include +#include +#endif + #include +#ifdef __cplusplus + struct block_param { char *name; char *value; @@ -37,6 +45,8 @@ struct block_param { bool used; }; +#endif + struct config_param { char *value; unsigned int line; @@ -51,6 +61,14 @@ struct config_param { bool used; }; +#ifdef __cplusplus + +struct ConfigData { + std::array params; +}; + +#endif + #ifdef __cplusplus extern "C" { #endif diff --git a/src/ConfigFile.cxx b/src/ConfigFile.cxx index af619c0b2..d10c90463 100644 --- a/src/ConfigFile.cxx +++ b/src/ConfigFile.cxx @@ -47,7 +47,7 @@ extern "C" { #define CONF_COMMENT '#' -static GSList *config_params[unsigned(CONF_MAX)]; +static ConfigData config_data; static void config_param_free_callback(gpointer data, G_GNUC_UNUSED gpointer user_data) @@ -59,10 +59,9 @@ config_param_free_callback(gpointer data, G_GNUC_UNUSED gpointer user_data) void config_global_finish(void) { - for (unsigned i = 0; i < G_N_ELEMENTS(config_params); ++i) { - g_slist_foreach(config_params[i], - config_param_free_callback, NULL); - g_slist_free(config_params[i]); + for (auto i : config_data.params) { + g_slist_foreach(i, config_param_free_callback, NULL); + g_slist_free(i); } } @@ -92,8 +91,8 @@ config_param_check(gpointer data, G_GNUC_UNUSED gpointer user_data) void config_global_check(void) { - for (unsigned i = 0; i < G_N_ELEMENTS(config_params); ++i) - g_slist_foreach(config_params[i], config_param_check, NULL); + for (auto i : config_data.params) + g_slist_foreach(i, config_param_check, NULL); } static bool @@ -244,7 +243,7 @@ ReadConfigFile(const Path &path, GError **error_r) const unsigned i = ParseConfigOptionName(name); const ConfigTemplate &option = config_templates[i]; - GSList *¶ms = config_params[i]; + GSList *¶ms = config_data.params[i]; if (params != NULL && !option.repeatable) { param = (struct config_param *)params->data; @@ -323,7 +322,7 @@ ReadConfigFile(const Path &path, GError **error_r) const struct config_param * config_get_next_param(ConfigOption option, const struct config_param * last) { - GSList *node = config_params[unsigned(option)]; + GSList *node = config_data.params[unsigned(option)]; if (last) { node = g_slist_find(node, last);