mod_plugin, just for tarzeau
git-svn-id: https://svn.musicpd.org/mpd/trunk@1263 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
2c1f5365eb
commit
d9f5cca9b8
17
configure.ac
17
configure.ac
@ -40,8 +40,9 @@ AC_ARG_ENABLE(flac,[ --disable-flac disable flac support],,enable_flac=yes)
|
|||||||
AC_ARG_ENABLE(mp3,[ --disable-mp3 disable mp3 support],,enable_mp3=yes)
|
AC_ARG_ENABLE(mp3,[ --disable-mp3 disable mp3 support],,enable_mp3=yes)
|
||||||
AC_ARG_ENABLE(aac,[ --disable-aac disable AAC support],,enable_aac=yes)
|
AC_ARG_ENABLE(aac,[ --disable-aac disable AAC support],,enable_aac=yes)
|
||||||
AC_ARG_ENABLE(audiofile,[ --disable-audiofile disable audiofile support, disables wave support],,enable_audiofile=yes)
|
AC_ARG_ENABLE(audiofile,[ --disable-audiofile disable audiofile support, disables wave support],,enable_audiofile=yes)
|
||||||
AC_ARG_ENABLE(mpd_mad,[ --enable-mpd-mad use mpd libmad],use_mpd_mad=yes,)
|
AC_ARG_ENABLE(mod,[ --disable-mod disable MOD support],,enable_mod=yes)
|
||||||
AC_ARG_ENABLE(id3,[ --disable-id3 disable id3 support],,enable_id3=yes)
|
AC_ARG_ENABLE(id3,[ --disable-id3 disable id3 support],,enable_id3=yes)
|
||||||
|
AC_ARG_ENABLE(mpd_mad,[ --enable-mpd-mad use mpd libmad],use_mpd_mad=yes,)
|
||||||
AC_ARG_ENABLE(mpd_id3tag,[ --enable-mpd-id3tag use mpd libid3tag],use_mpd_id3tag=yes,)
|
AC_ARG_ENABLE(mpd_id3tag,[ --enable-mpd-id3tag use mpd libid3tag],use_mpd_id3tag=yes,)
|
||||||
|
|
||||||
AC_ARG_WITH(iconv,[ --with-iconv=PFX Prefix where iconv is installed (optional)], iconv_prefix="$withval", iconv_prefix="")
|
AC_ARG_WITH(iconv,[ --with-iconv=PFX Prefix where iconv is installed (optional)], iconv_prefix="$withval", iconv_prefix="")
|
||||||
@ -473,6 +474,14 @@ if test x$enable_audiofile = xyes; then
|
|||||||
AC_DEFINE(HAVE_AUDIOFILE,1,[Define for audiofile support])
|
AC_DEFINE(HAVE_AUDIOFILE,1,[Define for audiofile support])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if test x$enable_mod = xyes; then
|
||||||
|
AM_PATH_LIBMIKMOD(3.1.7, MPD_CFLAGS="$MPD_CFLAGS $LIBMIKMOD_CFLAGS"
|
||||||
|
MPD_LIBS="$MPD_LIBS $LIBMIKMOD_LIBS", enable_mod=no)
|
||||||
|
if test x$enable_mod = xyes; then
|
||||||
|
AC_DEFINE(HAVE_MIKMOD, 1, [Define for mikmod support])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
AC_OUTPUT(src/mp4ff/Makefile doc/Makefile src/Makefile Makefile )
|
AC_OUTPUT(src/mp4ff/Makefile doc/Makefile src/Makefile Makefile )
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
@ -565,6 +574,12 @@ else
|
|||||||
echo "MP4/AAC support ...............disabled"
|
echo "MP4/AAC support ...............disabled"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if test x$enable_mod = xyes; then
|
||||||
|
echo "MOD support ...................enabled"
|
||||||
|
else
|
||||||
|
echo "MOD support ...................disabled"
|
||||||
|
fi
|
||||||
|
|
||||||
echo ""
|
echo ""
|
||||||
echo "##########################################"
|
echo "##########################################"
|
||||||
echo ""
|
echo ""
|
||||||
|
@ -3,7 +3,8 @@ SUBDIRS = $(ID3_SUBDIR) $(MAD_SUBDIR) $(MP4FF_SUBDIR)
|
|||||||
|
|
||||||
mpd_inputPlugins = inputPlugins/mp3_plugin.c inputPlugins/ogg_plugin.c \
|
mpd_inputPlugins = inputPlugins/mp3_plugin.c inputPlugins/ogg_plugin.c \
|
||||||
inputPlugins/flac_plugin.c inputPlugins/audiofile_plugin.c \
|
inputPlugins/flac_plugin.c inputPlugins/audiofile_plugin.c \
|
||||||
inputPlugins/mp4_plugin.c inputPlugins/aac_plugin.c
|
inputPlugins/mp4_plugin.c inputPlugins/aac_plugin.c \
|
||||||
|
inputPlugins/mod_plugin.c
|
||||||
|
|
||||||
mpd_headers = buffer2array.h interface.h command.h playlist.h ls.h \
|
mpd_headers = buffer2array.h interface.h command.h playlist.h ls.h \
|
||||||
song.h list.h directory.h tables.h utils.h path.h \
|
song.h list.h directory.h tables.h utils.h path.h \
|
||||||
|
@ -11,10 +11,13 @@ void loadInputPlugin(InputPlugin * inputPlugin) {
|
|||||||
if(!inputPlugin) return;
|
if(!inputPlugin) return;
|
||||||
if(!inputPlugin->name) return;
|
if(!inputPlugin->name) return;
|
||||||
|
|
||||||
|
if(inputPlugin->initFunc && inputPlugin->initFunc() < 0) return;
|
||||||
|
|
||||||
insertInList(inputPlugin_list, inputPlugin->name, (void *)inputPlugin);
|
insertInList(inputPlugin_list, inputPlugin->name, (void *)inputPlugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
void unloadInputPlugin(InputPlugin * inputPlugin) {
|
void unloadInputPlugin(InputPlugin * inputPlugin) {
|
||||||
|
if(inputPlugin->finishFunc) inputPlugin->finishFunc();
|
||||||
deleteFromList(inputPlugin_list, inputPlugin->name);
|
deleteFromList(inputPlugin_list, inputPlugin->name);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,6 +76,7 @@ extern InputPlugin flacPlugin;
|
|||||||
extern InputPlugin audiofilePlugin;
|
extern InputPlugin audiofilePlugin;
|
||||||
extern InputPlugin mp4Plugin;
|
extern InputPlugin mp4Plugin;
|
||||||
extern InputPlugin aacPlugin;
|
extern InputPlugin aacPlugin;
|
||||||
|
extern InputPlugin modPlugin;
|
||||||
|
|
||||||
void initInputPlugins() {
|
void initInputPlugins() {
|
||||||
inputPlugin_list = makeList(NULL);
|
inputPlugin_list = makeList(NULL);
|
||||||
@ -83,7 +87,7 @@ void initInputPlugins() {
|
|||||||
loadInputPlugin(&flacPlugin);
|
loadInputPlugin(&flacPlugin);
|
||||||
loadInputPlugin(&audiofilePlugin);
|
loadInputPlugin(&audiofilePlugin);
|
||||||
loadInputPlugin(&mp4Plugin);
|
loadInputPlugin(&mp4Plugin);
|
||||||
loadInputPlugin(&aacPlugin);
|
loadInputPlugin(&modPlugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
void finishInputPlugins() {
|
void finishInputPlugins() {
|
||||||
|
@ -10,6 +10,10 @@
|
|||||||
#define INPUT_PLUGIN_STREAM_FILE 0x01
|
#define INPUT_PLUGIN_STREAM_FILE 0x01
|
||||||
#define INPUT_PLUGIN_STREAM_URL 0x02
|
#define INPUT_PLUGIN_STREAM_URL 0x02
|
||||||
|
|
||||||
|
typedef int (* InputPlugin_initFunc) ();
|
||||||
|
|
||||||
|
typedef void (* InputPlugin_finishFunc) ();
|
||||||
|
|
||||||
typedef int (* InputPlugin_streamDecodeFunc) (OutputBuffer *, DecoderControl *,
|
typedef int (* InputPlugin_streamDecodeFunc) (OutputBuffer *, DecoderControl *,
|
||||||
InputStream *);
|
InputStream *);
|
||||||
|
|
||||||
@ -21,6 +25,8 @@ typedef MpdTag * (* InputPlugin_tagDupFunc) (char * file);
|
|||||||
|
|
||||||
typedef struct _InputPlugin {
|
typedef struct _InputPlugin {
|
||||||
char * name;
|
char * name;
|
||||||
|
InputPlugin_initFunc initFunc;
|
||||||
|
InputPlugin_finishFunc finishFunc;
|
||||||
InputPlugin_streamDecodeFunc streamDecodeFunc;
|
InputPlugin_streamDecodeFunc streamDecodeFunc;
|
||||||
InputPlugin_fileDecodeFunc fileDecodeFunc;
|
InputPlugin_fileDecodeFunc fileDecodeFunc;
|
||||||
InputPlugin_tagDupFunc tagDupFunc;
|
InputPlugin_tagDupFunc tagDupFunc;
|
||||||
|
@ -415,6 +415,8 @@ InputPlugin aacPlugin =
|
|||||||
{
|
{
|
||||||
"aac",
|
"aac",
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
aac_decode,
|
aac_decode,
|
||||||
aacTagDup,
|
aacTagDup,
|
||||||
INPUT_PLUGIN_STREAM_FILE,
|
INPUT_PLUGIN_STREAM_FILE,
|
||||||
@ -430,6 +432,8 @@ InputPlugin aacPlugin =
|
|||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
0,
|
0,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -555,6 +555,8 @@ InputPlugin flacPlugin =
|
|||||||
{
|
{
|
||||||
"flac",
|
"flac",
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
flac_decode,
|
flac_decode,
|
||||||
flacTagDup,
|
flacTagDup,
|
||||||
INPUT_PLUGIN_STREAM_FILE,
|
INPUT_PLUGIN_STREAM_FILE,
|
||||||
@ -570,6 +572,8 @@ InputPlugin flacPlugin =
|
|||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
0,
|
0,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -634,6 +634,8 @@ char * mp3_mimeTypes[] = {"audio/mpeg", NULL};
|
|||||||
InputPlugin mp3Plugin =
|
InputPlugin mp3Plugin =
|
||||||
{
|
{
|
||||||
"mp3",
|
"mp3",
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
mp3_decode,
|
mp3_decode,
|
||||||
NULL,
|
NULL,
|
||||||
mp3_tagDup,
|
mp3_tagDup,
|
||||||
@ -649,6 +651,8 @@ InputPlugin mp3Plugin =
|
|||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
0,
|
0,
|
||||||
NULL,
|
NULL,
|
||||||
NULL
|
NULL
|
||||||
|
@ -403,6 +403,8 @@ InputPlugin mp4Plugin =
|
|||||||
{
|
{
|
||||||
"mp4",
|
"mp4",
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
mp4_decode,
|
mp4_decode,
|
||||||
mp4TagDup,
|
mp4TagDup,
|
||||||
INPUT_PLUGIN_STREAM_FILE,
|
INPUT_PLUGIN_STREAM_FILE,
|
||||||
@ -417,6 +419,8 @@ InputPlugin mp4Plugin =
|
|||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
0,
|
0,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -335,6 +335,8 @@ char * oggMimeTypes[] = {"application/ogg", NULL};
|
|||||||
InputPlugin oggPlugin =
|
InputPlugin oggPlugin =
|
||||||
{
|
{
|
||||||
"ogg",
|
"ogg",
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
ogg_decode,
|
ogg_decode,
|
||||||
NULL,
|
NULL,
|
||||||
oggTagDup,
|
oggTagDup,
|
||||||
@ -347,6 +349,8 @@ InputPlugin oggPlugin =
|
|||||||
|
|
||||||
InputPlugin oggPlugin =
|
InputPlugin oggPlugin =
|
||||||
{
|
{
|
||||||
|
NULL,
|
||||||
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
Loading…
Reference in New Issue
Block a user