Commit f70d2f58 authored by Max Kellermann's avatar Max Kellermann

input_stream: moved input_stream_global_init() to input_init.c

parent 67b0ab71
...@@ -91,6 +91,7 @@ mpd_headers = \ ...@@ -91,6 +91,7 @@ mpd_headers = \
src/decoder/flac_pcm.h \ src/decoder/flac_pcm.h \
src/decoder/_flac_common.h \ src/decoder/_flac_common.h \
src/decoder/_ogg_common.h \ src/decoder/_ogg_common.h \
src/input_init.h \
src/input_plugin.h \ src/input_plugin.h \
src/input_registry.h \ src/input_registry.h \
src/input_stream.h \ src/input_stream.h \
...@@ -570,6 +571,7 @@ INPUT_LIBS = \ ...@@ -570,6 +571,7 @@ INPUT_LIBS = \
$(MMS_LIBS) $(MMS_LIBS)
INPUT_SRC = \ INPUT_SRC = \
src/input_init.c \
src/input_registry.c \ src/input_registry.c \
src/input_stream.c \ src/input_stream.c \
src/input/file_input_plugin.c src/input/file_input_plugin.c
......
/*
* Copyright (C) 2003-2009 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.
*/
#include "config.h"
#include "input_init.h"
#include "input_plugin.h"
#include "input_registry.h"
#include "conf.h"
#include <string.h>
/**
* Find the "input" configuration block for the specified plugin.
*
* @param plugin_name the name of the input plugin
* @return the configuration block, or NULL if none was configured
*/
static const struct config_param *
input_plugin_config(const char *plugin_name)
{
const struct config_param *param = NULL;
while ((param = config_get_next_param(CONF_INPUT, param)) != NULL) {
const char *name =
config_get_block_string(param, "plugin", NULL);
if (name == NULL)
g_error("input configuration without 'plugin' name in line %d",
param->line);
if (strcmp(name, plugin_name) == 0)
return param;
}
return NULL;
}
void input_stream_global_init(void)
{
for (unsigned i = 0; input_plugins[i] != NULL; ++i) {
const struct input_plugin *plugin = input_plugins[i];
const struct config_param *param =
input_plugin_config(plugin->name);
if (!config_get_block_bool(param, "enabled", true))
/* the plugin is disabled in mpd.conf */
continue;
if (plugin->init == NULL || plugin->init(param))
input_plugins_enabled[i] = true;
}
}
void input_stream_global_finish(void)
{
for (unsigned i = 0; input_plugins[i] != NULL; ++i)
if (input_plugins_enabled[i] &&
input_plugins[i]->finish != NULL)
input_plugins[i]->finish();
}
/*
* Copyright (C) 2003-2009 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_INPUT_INIT_H
#define MPD_INPUT_INIT_H
#include "check.h"
/**
* Initializes this library and all input_stream implementations.
*/
void input_stream_global_init(void);
/**
* Deinitializes this library and all input_stream implementations.
*/
void input_stream_global_finish(void);
#endif
...@@ -21,60 +21,9 @@ ...@@ -21,60 +21,9 @@
#include "input_stream.h" #include "input_stream.h"
#include "input_registry.h" #include "input_registry.h"
#include "input_plugin.h" #include "input_plugin.h"
#include "conf.h"
#include <glib.h> #include <glib.h>
#include <assert.h> #include <assert.h>
#include <string.h>
/**
* Find the "input" configuration block for the specified plugin.
*
* @param plugin_name the name of the input plugin
* @return the configuration block, or NULL if none was configured
*/
static const struct config_param *
input_plugin_config(const char *plugin_name)
{
const struct config_param *param = NULL;
while ((param = config_get_next_param(CONF_INPUT, param)) != NULL) {
const char *name =
config_get_block_string(param, "plugin", NULL);
if (name == NULL)
g_error("input configuration without 'plugin' name in line %d",
param->line);
if (strcmp(name, plugin_name) == 0)
return param;
}
return NULL;
}
void input_stream_global_init(void)
{
for (unsigned i = 0; input_plugins[i] != NULL; ++i) {
const struct input_plugin *plugin = input_plugins[i];
const struct config_param *param =
input_plugin_config(plugin->name);
if (!config_get_block_bool(param, "enabled", true))
/* the plugin is disabled in mpd.conf */
continue;
if (plugin->init == NULL || plugin->init(param))
input_plugins_enabled[i] = true;
}
}
void input_stream_global_finish(void)
{
for (unsigned i = 0; input_plugins[i] != NULL; ++i)
if (input_plugins_enabled[i] &&
input_plugins[i]->finish != NULL)
input_plugins[i]->finish();
}
bool bool
input_stream_open(struct input_stream *is, const char *url) input_stream_open(struct input_stream *is, const char *url)
......
...@@ -76,16 +76,6 @@ struct input_stream { ...@@ -76,16 +76,6 @@ struct input_stream {
}; };
/** /**
* Initializes this library and all input_stream implementations.
*/
void input_stream_global_init(void);
/**
* Deinitializes this library and all input_stream implementations.
*/
void input_stream_global_finish(void);
/**
* Opens a new input stream. You may not access it until the "ready" * Opens a new input stream. You may not access it until the "ready"
* flag is set. * flag is set.
* *
......
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
#include "permission.h" #include "permission.h"
#include "replay_gain.h" #include "replay_gain.h"
#include "decoder_list.h" #include "decoder_list.h"
#include "input_stream.h" #include "input_init.h"
#include "playlist_list.h" #include "playlist_list.h"
#include "state_file.h" #include "state_file.h"
#include "tag.h" #include "tag.h"
......
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
*/ */
#include "config.h" #include "config.h"
#include "input_init.h"
#include "input_stream.h" #include "input_stream.h"
#include "tag_pool.h" #include "tag_pool.h"
#include "tag_save.h" #include "tag_save.h"
......
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include "config.h" #include "config.h"
#include "decoder_list.h" #include "decoder_list.h"
#include "decoder_api.h" #include "decoder_api.h"
#include "input_init.h"
#include "input_stream.h" #include "input_stream.h"
#include "audio_format.h" #include "audio_format.h"
#include "pcm_volume.h" #include "pcm_volume.h"
......
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include "config.h" #include "config.h"
#include "decoder_list.h" #include "decoder_list.h"
#include "decoder_api.h" #include "decoder_api.h"
#include "input_init.h"
#include "input_stream.h" #include "input_stream.h"
#include "audio_format.h" #include "audio_format.h"
#include "pcm_volume.h" #include "pcm_volume.h"
......
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
*/ */
#include "config.h" #include "config.h"
#include "input_init.h"
#include "input_stream.h" #include "input_stream.h"
#include "tag_pool.h" #include "tag_pool.h"
#include "tag_save.h" #include "tag_save.h"
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment