aboutsummaryrefslogtreecommitdiffstats
path: root/src/decoder_list.c
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2009-02-15 18:35:19 +0100
committerMax Kellermann <max@duempel.org>2009-02-15 18:35:19 +0100
commit6cfacc778c11565adc5af75cfa4579c1b6925c93 (patch)
tree33ff5133731d4164e3c64dc82bb34989d3dab6f2 /src/decoder_list.c
parentdec5d48f80428575c7a1b9eeba961b0055156500 (diff)
downloadmpd-6cfacc778c11565adc5af75cfa4579c1b6925c93.tar.gz
mpd-6cfacc778c11565adc5af75cfa4579c1b6925c93.tar.xz
mpd-6cfacc778c11565adc5af75cfa4579c1b6925c93.zip
decoder_list: added configuration block "decoder"
The "decoder" configuration block may contain the configuration of one decoder plugin.
Diffstat (limited to 'src/decoder_list.c')
-rw-r--r--src/decoder_list.c30
1 files changed, 29 insertions, 1 deletions
diff --git a/src/decoder_list.c b/src/decoder_list.c
index f0cf8625b..a644a6370 100644
--- a/src/decoder_list.c
+++ b/src/decoder_list.c
@@ -20,6 +20,7 @@
#include "decoder_plugin.h"
#include "utils.h"
#include "config.h"
+#include "conf.h"
#include <glib.h>
@@ -185,12 +186,39 @@ void decoder_plugin_print_all_decoders(FILE * fp)
fflush(fp);
}
+/**
+ * Find the "decoder" configuration block for the specified plugin.
+ *
+ * @param plugin_name the name of the decoder plugin
+ * @return the configuration block, or NULL if none was configured
+ */
+static const struct config_param *
+decoder_plugin_config(const char *plugin_name)
+{
+ const struct config_param *param = NULL;
+
+ while ((param = config_get_next_param(CONF_DECODER, param)) != NULL) {
+ const char *name =
+ config_get_block_string(param, "plugin", NULL);
+ if (name == NULL)
+ g_error("decoder configuration without 'plugin' name in line %d",
+ param->line);
+
+ if (strcmp(name, plugin_name) == 0)
+ return param;
+ }
+
+ return NULL;
+}
+
void decoder_plugin_init_all(void)
{
for (unsigned i = 0; i < num_decoder_plugins; ++i) {
const struct decoder_plugin *plugin = decoder_plugins[i];
+ const struct config_param *param =
+ decoder_plugin_config(plugin->name);
- if (decoder_plugin_init(plugin, NULL))
+ if (decoder_plugin_init(plugin, param))
decoder_plugins_enabled[i] = true;
}
}