output: static audio_output_plugin list as array

Instead of having to register each output plugin, store them
statically in an array.  This eliminates the need for the List library
here, and saves some small allocations during startup.
This commit is contained in:
Max Kellermann 2008-09-08 11:43:13 +02:00
parent a0103dd05c
commit be046b25a4
8 changed files with 104 additions and 80 deletions

View File

@ -34,6 +34,7 @@ mpd_headers = \
audio.h \ audio.h \
audioOutput.h \ audioOutput.h \
output_api.h \ output_api.h \
output_list.h \
buffer2array.h \ buffer2array.h \
charConv.h \ charConv.h \
command.h \ command.h \
@ -107,6 +108,7 @@ mpd_SOURCES = \
notify.c \ notify.c \
audio.c \ audio.c \
audioOutput.c \ audioOutput.c \
output_list.c \
buffer2array.c \ buffer2array.c \
charConv.c \ charConv.c \
command.c \ command.c \

View File

@ -82,29 +82,12 @@ int cmpAudioFormat(const struct audio_format *f1, const struct audio_format *f2)
return 1; return 1;
} }
void loadAudioDrivers(void)
{
initAudioOutputPlugins();
loadAudioOutputPlugin(&shoutPlugin);
loadAudioOutputPlugin(&nullPlugin);
loadAudioOutputPlugin(&fifoPlugin);
loadAudioOutputPlugin(&alsaPlugin);
loadAudioOutputPlugin(&aoPlugin);
loadAudioOutputPlugin(&ossPlugin);
loadAudioOutputPlugin(&osxPlugin);
loadAudioOutputPlugin(&pulsePlugin);
loadAudioOutputPlugin(&mvpPlugin);
loadAudioOutputPlugin(&jackPlugin);
}
/* make sure initPlayerData is called before this function!! */ /* make sure initPlayerData is called before this function!! */
void initAudioDriver(void) void initAudioDriver(void)
{ {
ConfigParam *param = NULL; ConfigParam *param = NULL;
unsigned int i; unsigned int i;
loadAudioDrivers();
audioOutputArraySize = audio_output_count(); audioOutputArraySize = audio_output_count();
audioDeviceStates = xmalloc(sizeof(enum ad_state) * audioDeviceStates = xmalloc(sizeof(enum ad_state) *
audioOutputArraySize); audioOutputArraySize);

View File

@ -71,5 +71,4 @@ void readAudioDevicesState(FILE *fp);
void saveAudioDevicesState(FILE *fp); void saveAudioDevicesState(FILE *fp);
void loadAudioDrivers(void);
#endif #endif

View File

@ -18,8 +18,8 @@
#include "audioOutput.h" #include "audioOutput.h"
#include "output_api.h" #include "output_api.h"
#include "output_list.h"
#include "list.h"
#include "log.h" #include "log.h"
#include "pcm_utils.h" #include "pcm_utils.h"
#include "utils.h" #include "utils.h"
@ -30,33 +30,6 @@
#define AUDIO_OUTPUT_NAME "name" #define AUDIO_OUTPUT_NAME "name"
#define AUDIO_OUTPUT_FORMAT "format" #define AUDIO_OUTPUT_FORMAT "format"
static List *audioOutputPluginList;
void loadAudioOutputPlugin(struct audio_output_plugin *audioOutputPlugin)
{
if (!audioOutputPlugin->name)
return;
insertInList(audioOutputPluginList, audioOutputPlugin->name,
audioOutputPlugin);
}
void unloadAudioOutputPlugin(struct audio_output_plugin *audioOutputPlugin)
{
if (!audioOutputPlugin->name)
return;
deleteFromList(audioOutputPluginList, audioOutputPlugin->name);
}
void initAudioOutputPlugins(void)
{
audioOutputPluginList = makeList(NULL, 0);
}
void finishAudioOutputPlugins(void)
{
freeList(audioOutputPluginList);
}
#define getBlockParam(name, str, force) { \ #define getBlockParam(name, str, force) { \
bp = getBlockParam(param, name); \ bp = getBlockParam(param, name); \
if(force && bp == NULL) { \ if(force && bp == NULL) { \
@ -69,11 +42,10 @@ void finishAudioOutputPlugins(void)
int initAudioOutput(struct audio_output *ao, ConfigParam * param) int initAudioOutput(struct audio_output *ao, ConfigParam * param)
{ {
void *data = NULL;
const char *name = NULL; const char *name = NULL;
char *format = NULL; char *format = NULL;
BlockParam *bp = NULL; BlockParam *bp = NULL;
struct audio_output_plugin *plugin = NULL; const struct audio_output_plugin *plugin = NULL;
if (param) { if (param) {
const char *type = NULL; const char *type = NULL;
@ -82,21 +54,19 @@ int initAudioOutput(struct audio_output *ao, ConfigParam * param)
getBlockParam(AUDIO_OUTPUT_TYPE, type, 1); getBlockParam(AUDIO_OUTPUT_TYPE, type, 1);
getBlockParam(AUDIO_OUTPUT_FORMAT, format, 0); getBlockParam(AUDIO_OUTPUT_FORMAT, format, 0);
if (!findInList(audioOutputPluginList, type, &data)) { plugin = audio_output_plugin_get(type);
if (plugin == NULL) {
FATAL("couldn't find audio output plugin for type " FATAL("couldn't find audio output plugin for type "
"\"%s\" at line %i\n", type, param->line); "\"%s\" at line %i\n", type, param->line);
} }
plugin = (struct audio_output_plugin *) data;
} else { } else {
ListNode *node = audioOutputPluginList->firstNode; unsigned i;
WARNING("No \"%s\" defined in config file\n", WARNING("No \"%s\" defined in config file\n",
CONF_AUDIO_OUTPUT); CONF_AUDIO_OUTPUT);
WARNING("Attempt to detect audio output device\n"); WARNING("Attempt to detect audio output device\n");
while (node) { audio_output_plugins_for_each(plugin, i) {
plugin = (struct audio_output_plugin *) node->data;
if (plugin->testDefaultDeviceFunc) { if (plugin->testDefaultDeviceFunc) {
WARNING("Attempting to detect a %s audio " WARNING("Attempting to detect a %s audio "
"device\n", plugin->name); "device\n", plugin->name);
@ -106,10 +76,9 @@ int initAudioOutput(struct audio_output *ao, ConfigParam * param)
break; break;
} }
} }
node = node->nextNode;
} }
if (!node) { if (plugin == NULL) {
WARNING("Unable to detect an audio device\n"); WARNING("Unable to detect an audio device\n");
return 0; return 0;
} }
@ -250,14 +219,12 @@ void sendMetadataToAudioOutput(struct audio_output *audioOutput,
void printAllOutputPluginTypes(FILE * fp) void printAllOutputPluginTypes(FILE * fp)
{ {
ListNode *node = audioOutputPluginList->firstNode; unsigned i;
struct audio_output_plugin *plugin; const struct audio_output_plugin *plugin;
while (node) { audio_output_plugins_for_each(plugin, i)
plugin = (struct audio_output_plugin *) node->data;
fprintf(fp, "%s ", plugin->name); fprintf(fp, "%s ", plugin->name);
node = node->nextNode;
}
fprintf(fp, "\n"); fprintf(fp, "\n");
fflush(fp); fflush(fp);
} }

View File

@ -29,12 +29,6 @@ struct audio_output_plugin;
struct audio_format; struct audio_format;
struct tag; struct tag;
void initAudioOutputPlugins(void);
void finishAudioOutputPlugins(void);
void loadAudioOutputPlugin(struct audio_output_plugin *audioOutputPlugin);
void unloadAudioOutputPlugin(struct audio_output_plugin *audioOutputPlugin);
int initAudioOutput(struct audio_output *, ConfigParam * param); int initAudioOutput(struct audio_output *, ConfigParam * param);
int openAudioOutput(struct audio_output *audioOutput, int openAudioOutput(struct audio_output *audioOutput,
const struct audio_format *audioFormat); const struct audio_format *audioFormat);
@ -49,15 +43,4 @@ void sendMetadataToAudioOutput(struct audio_output *audioOutput,
void printAllOutputPluginTypes(FILE * fp); void printAllOutputPluginTypes(FILE * fp);
extern struct audio_output_plugin shoutPlugin;
extern struct audio_output_plugin nullPlugin;
extern struct audio_output_plugin fifoPlugin;
extern struct audio_output_plugin alsaPlugin;
extern struct audio_output_plugin aoPlugin;
extern struct audio_output_plugin ossPlugin;
extern struct audio_output_plugin osxPlugin;
extern struct audio_output_plugin pulsePlugin;
extern struct audio_output_plugin mvpPlugin;
extern struct audio_output_plugin jackPlugin;
#endif #endif

View File

@ -136,7 +136,6 @@ static void version(void)
LOG("\n"); LOG("\n");
LOG("Supported outputs:\n"); LOG("Supported outputs:\n");
loadAudioDrivers();
printAllOutputPluginTypes(stdout); printAllOutputPluginTypes(stdout);
} }

59
src/output_list.c Normal file
View File

@ -0,0 +1,59 @@
/* the Music Player Daemon (MPD)
* Copyright (C) 2008 Max Kellermann <max@duempel.org>
* This project's homepage is: 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#include "output_list.h"
#include "output_api.h"
#include "os_compat.h"
extern const struct audio_output_plugin shoutPlugin;
extern const struct audio_output_plugin nullPlugin;
extern const struct audio_output_plugin fifoPlugin;
extern const struct audio_output_plugin alsaPlugin;
extern const struct audio_output_plugin aoPlugin;
extern const struct audio_output_plugin ossPlugin;
extern const struct audio_output_plugin osxPlugin;
extern const struct audio_output_plugin pulsePlugin;
extern const struct audio_output_plugin mvpPlugin;
extern const struct audio_output_plugin jackPlugin;
const struct audio_output_plugin *audio_output_plugins[] = {
&shoutPlugin,
&nullPlugin,
&fifoPlugin,
&alsaPlugin,
&aoPlugin,
&ossPlugin,
&osxPlugin,
&pulsePlugin,
&mvpPlugin,
&jackPlugin,
NULL
};
const struct audio_output_plugin *
audio_output_plugin_get(const char *name)
{
unsigned int i;
const struct audio_output_plugin *plugin;
audio_output_plugins_for_each(plugin, i)
if (strcmp(audio_output_plugins[i]->name, name) == 0)
return audio_output_plugins[i];
return NULL;
}

32
src/output_list.h Normal file
View File

@ -0,0 +1,32 @@
/* the Music Player Daemon (MPD)
* Copyright (C) 2008 Max Kellermann <max@duempel.org>
* This project's homepage is: 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef OUTPUT_LIST_H
#define OUTPUT_LIST_H
extern const struct audio_output_plugin *audio_output_plugins[];
const struct audio_output_plugin *
audio_output_plugin_get(const char *name);
#define audio_output_plugins_for_each(plugin, i) \
for (i = 0; (plugin = audio_output_plugins[i]) != NULL; ++i) \
if (plugin->name != NULL)
#endif