aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorWarren Dukes <warren.dukes@gmail.com>2004-05-31 01:21:17 +0000
committerWarren Dukes <warren.dukes@gmail.com>2004-05-31 01:21:17 +0000
commitfd6aa253594e18877ca2380961c0425a7de21b2e (patch)
treeb86fc645573adef9c0de9bd5f22eadffe3d16814 /src
parentd7893a3e76d261b33b83fd9333d85892b3308594 (diff)
downloadmpd-fd6aa253594e18877ca2380961c0425a7de21b2e.tar.gz
mpd-fd6aa253594e18877ca2380961c0425a7de21b2e.tar.xz
mpd-fd6aa253594e18877ca2380961c0425a7de21b2e.zip
mp3 and ogg plugin stuff
git-svn-id: https://svn.musicpd.org/mpd/trunk@1245 09075e82-0dd4-0310-85a5-a0d7c8717e4f
Diffstat (limited to 'src')
-rw-r--r--src/Makefile.am13
-rw-r--r--src/decode.c100
-rw-r--r--src/inputPlugin.c82
-rw-r--r--src/inputPlugin.h17
-rw-r--r--src/inputPlugins/mp3_plugin.c (renamed from src/mp3_decode.c)71
-rw-r--r--src/inputPlugins/ogg_plugin.c (renamed from src/ogg_decode.c)106
-rw-r--r--src/inputStream_http.c4
-rw-r--r--src/ls.c24
-rw-r--r--src/ls.h18
-rw-r--r--src/main.c3
-rw-r--r--src/mp3_decode.h38
-rw-r--r--src/ogg_decode.h34
-rw-r--r--src/player.c53
-rw-r--r--src/player.h2
-rw-r--r--src/song.c74
-rw-r--r--src/tag.c84
-rw-r--r--src/tag.h4
17 files changed, 230 insertions, 497 deletions
diff --git a/src/Makefile.am b/src/Makefile.am
index 5f783e6ac..ead005df4 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -1,21 +1,24 @@
bin_PROGRAMS = mpd
SUBDIRS = $(ID3_SUBDIR) $(MAD_SUBDIR) $(MP4FF_SUBDIR)
+
+mpd_inputPlugins = inputPlugins/mp3_plugin.c inputPlugins/ogg_plugin.c
+
mpd_headers = buffer2array.h interface.h command.h playlist.h ls.h \
- song.h list.h directory.h tables.h utils.h path.h mp3_decode.h \
- tag.h player.h listen.h conf.h ogg_decode.h volume.h flac_decode.h \
+ song.h list.h directory.h tables.h utils.h path.h \
+ tag.h player.h listen.h conf.h volume.h flac_decode.h \
audio.h playerData.h stats.h myfprintf.h sig_handlers.h decode.h log.h \
audiofile_decode.h charConv.h permission.h mpd_types.h pcm_utils.h \
mp4_decode.h aac_decode.h signal_check.h utf8.h inputStream.h \
outputBuffer.h replayGain.h inputStream_file.h inputStream_http.h \
inputPlugin.h
mpd_SOURCES = main.c buffer2array.c interface.c command.c playlist.c ls.c \
- song.c list.c directory.c tables.c utils.c path.c mp3_decode.c \
- tag.c player.c listen.c conf.c ogg_decode.c volume.c flac_decode.c \
+ song.c list.c directory.c tables.c utils.c path.c \
+ tag.c player.c listen.c conf.c volume.c flac_decode.c \
audio.c playerData.c stats.c myfprintf.c sig_handlers.c decode.c log.c \
audiofile_decode.c charConv.c permission.c pcm_utils.c mp4_decode.c \
aac_decode.c signal_check.c utf8.c inputStream.c outputBuffer.c \
replayGain.c inputStream_file.c inputStream_http.c inputPlugin.c \
- $(mpd_headers)
+ $(mpd_headers) $(mpd_inputPlugins)
mpd_CFLAGS = $(MPD_CFLAGS)
mpd_LDADD = $(MPD_LIBS) $(ID3_LIB) $(MAD_LIB) $(MP4FF_LIB)
diff --git a/src/decode.c b/src/decode.c
index d5d3ab41b..ec4774fa9 100644
--- a/src/decode.c
+++ b/src/decode.c
@@ -28,23 +28,6 @@
#include "sig_handlers.h"
#include "ls.h"
-#ifdef HAVE_MAD
-#include "mp3_decode.h"
-#endif
-#ifdef HAVE_OGG
-#include "ogg_decode.h"
-#endif
-#ifdef HAVE_FLAC
-#include "flac_decode.h"
-#endif
-#ifdef HAVE_AUDIOFILE
-#include "audiofile_decode.h"
-#endif
-#ifdef HAVE_FAAD
-#include "mp4_decode.h"
-#include "aac_decode.h"
-#endif
-
#include <signal.h>
#include <sys/types.h>
#include <sys/time.h>
@@ -255,8 +238,7 @@ int decodeSeek(PlayerControl * pc, DecoderControl * dc, OutputBuffer * cb,
void decodeStart(PlayerControl * pc, OutputBuffer * cb, DecoderControl * dc) {
int ret;
InputStream inStream;
- int suffix = pc->fileSuffix;
- int decodeType = pc->decodeType;
+ InputPlugin * plugin;
strncpy(dc->file,pc->file,MAXPATHLEN);
dc->file[MAXPATHLEN] = '\0';
@@ -282,67 +264,33 @@ void decodeStart(PlayerControl * pc, OutputBuffer * cb, DecoderControl * dc) {
return;
}
- switch(decodeType) {
- case DECODE_TYPE_URL:
-#ifdef HAVE_OGG
- if(suffix == DECODE_SUFFIX_OGG || (inStream.mime &&
- 0 == strcmp(inStream.mime, "application/ogg")))
- {
- ret = ogg_decode(cb, dc, &inStream);
- break;
+ ret = DECODE_ERROR_UNKTYPE;
+ if(isRemoteUrl(pc->file)) {
+ plugin = getInputPluginFromMimeType(inStream.mime);
+ if(plugin == NULL) {
+ plugin = getInputPluginFromSuffix(getSuffix(dc->file));
}
-#endif
-#ifdef HAVE_MAD
- /*if(fileSuffix == DECODE_SUFFIX_MP3 || (inStream.mime &&
- 0 == strcmp(inStream.mime, "audio/mpeg")))*/
+ if(plugin && (plugin->streamTypes & INPUT_PLUGIN_STREAM_URL) &&
+ plugin->streamDecodeFunc)
{
- ret = mp3_decode(cb, dc, &inStream, 0);
- break;
- }
- ret = DECODE_ERROR_UNKTYPE;
-#endif
- case DECODE_TYPE_FILE:
-#ifdef HAVE_MAD
- if(suffix == DECODE_SUFFIX_MP3) {
- ret = mp3_decode(cb, dc, &inStream, 1);
- break;
- }
-#endif
-#ifdef HAVE_OGG
- if(suffix == DECODE_SUFFIX_OGG) {
- ret = ogg_decode(cb, dc, &inStream);
- break;
- }
-#endif
-#ifdef HAVE_FAAD
- if(suffix == DECODE_SUFFIX_AAC) {
- closeInputStream(&inStream);
- ret = aac_decode(cb,dc);
- break;
- }
- if(suffix == DECODE_SUFFIX_MP4) {
- closeInputStream(&inStream);
- ret = mp4_decode(cb,dc);
- break;
- }
-#endif
-#ifdef HAVE_FLAC
- if(suffix == DECODE_SUFFIX_FLAC) {
- closeInputStream(&inStream);
- ret = flac_decode(cb,dc);
- break;
- }
-#endif
-#ifdef HAVE_AUDIOFILE
- if(suffix == DECODE_SUFFIX_WAVE) {
- closeInputStream(&inStream);
- ret = audiofile_decode(cb,dc);
- break;
+ ret = plugin->streamDecodeFunc(cb, dc, &inStream);
}
-#endif
- default:
- ret = DECODE_ERROR_UNKTYPE;
}
+ else {
+ plugin = getInputPluginFromSuffix(getSuffix(dc->file));
+ if(plugin && (plugin->streamTypes && INPUT_PLUGIN_STREAM_FILE))
+ {
+ if(plugin->streamDecodeFunc) {
+ ret = plugin->streamDecodeFunc(cb, dc,
+ &inStream);
+ }
+ else if(plugin->fileDecodeFunc) {
+ closeInputStream(&inStream);
+ ret = plugin->fileDecodeFunc(cb, dc);
+ }
+ }
+ }
+
if(ret<0 || ret == DECODE_ERROR_UNKTYPE) {
strncpy(pc->erroredFile, dc->file, MAXPATHLEN);
pc->erroredFile[MAXPATHLEN] = '\0';
diff --git a/src/inputPlugin.c b/src/inputPlugin.c
index 2afe17719..d90a0e944 100644
--- a/src/inputPlugin.c
+++ b/src/inputPlugin.c
@@ -7,75 +7,10 @@
static List * inputPlugin_list = NULL;
-InputPlugin * newInputPlugin(char * name, InputPlugin_streamDecodeFunc
- streamDecodeFunc, InputPlugin_fileDecodeFunc fileDecodeFunc,
- InputPlugin_tagDupFunc tagDupFunc, unsigned char streamTypes)
-{
- InputPlugin * ret = malloc(sizeof(InputPlugin));
-
- memset(ret->name,0,INPUT_PLUGIN_NAME_LENGTH);
- strncpy(ret->name, name, INPUT_PLUGIN_NAME_LENGTH-1);
-
- ret->suffixes = NULL;
- ret->mimeTypes = NULL;
-
- ret->streamTypes = streamTypes;
-
- ret->streamDecodeFunc = streamDecodeFunc;
- ret->fileDecodeFunc = fileDecodeFunc;
- ret->tagDupFunc = tagDupFunc;
-
- return ret;
-}
-
-static void freeStringArray(char ** ptr) {
- if(ptr) {
- char ** tmp = ptr;
-
- while(*tmp) {
- if(*tmp) free(*tmp);
- tmp++;
- }
-
- free (ptr);
- }
-}
-
-void freeInputPlugin(InputPlugin * inPlugin) {
- freeStringArray(inPlugin->suffixes);
- freeStringArray(inPlugin->mimeTypes);
-
- free(inPlugin);
-}
-
-static char ** AddStringToArray(char ** array, char * string) {
- int arraySize = 1;
-
- if(array) {
- char ** tmp = array;
- while(*tmp) {
- arraySize++;
- tmp++;
- }
- }
-
- array = realloc(array, (arraySize+1)*sizeof(char *));
-
- array[arraySize-1] = strdup(string);
- array[arraySize] = NULL;
-
- return array;
-}
-
-void addSuffixToInputPlugin(InputPlugin * inPlugin, char * suffix) {
- inPlugin->suffixes = AddStringToArray(inPlugin->suffixes, suffix);
-}
-
-void addMimeTypeToInputPlugin(InputPlugin * inPlugin, char * mimeType) {
- inPlugin->mimeTypes = AddStringToArray(inPlugin->mimeTypes, mimeType);
-}
-
void loadInputPlugin(InputPlugin * inputPlugin) {
+ if(!inputPlugin) return;
+ if(!inputPlugin->name) return;
+
insertInList(inputPlugin_list, inputPlugin->name, (void *)inputPlugin);
}
@@ -96,11 +31,14 @@ InputPlugin * getInputPluginFromSuffix(char * suffix) {
ListNode * node = inputPlugin_list->firstNode;
InputPlugin * plugin = NULL;
+ if(suffix == NULL) return NULL;
+
while(node != NULL) {
plugin = node->data;
if(stringFoundInStringArray(plugin->suffixes, suffix)) {
return plugin;
}
+ node = node->nextNode;
}
return NULL;
@@ -115,6 +53,7 @@ InputPlugin * getInputPluginFromMimeType(char * mimeType) {
if(stringFoundInStringArray(plugin->mimeTypes, mimeType)) {
return plugin;
}
+ node = node->nextNode;
}
return NULL;
@@ -128,10 +67,15 @@ InputPlugin * getInputPluginFromName(char * name) {
return (InputPlugin *)plugin;
}
+extern InputPlugin mp3Plugin;
+extern InputPlugin oggPlugin;
+
void initInputPlugins() {
- inputPlugin_list = makeList((ListFreeDataFunc *)freeInputPlugin);
+ inputPlugin_list = makeList(NULL);
/* load plugins here */
+ loadInputPlugin(&mp3Plugin);
+ loadInputPlugin(&oggPlugin);
}
void finishInputPlugins() {
diff --git a/src/inputPlugin.h b/src/inputPlugin.h
index 9f57037fb..9e1ff395d 100644
--- a/src/inputPlugin.h
+++ b/src/inputPlugin.h
@@ -1,6 +1,7 @@
#ifndef INPUT_PLUGIN_H
#define INPUT_PLUGIN_H
+#include "../config.h"
#include "inputStream.h"
#include "decode.h"
#include "outputBuffer.h"
@@ -9,8 +10,6 @@
#define INPUT_PLUGIN_STREAM_FILE 0x01
#define INPUT_PLUGIN_STREAM_URL 0x02
-#define INPUT_PLUGIN_NAME_LENGTH 64
-
typedef int (* InputPlugin_streamDecodeFunc) (OutputBuffer *, DecoderControl *,
InputStream *);
@@ -19,7 +18,7 @@ typedef int (* InputPlugin_fileDecodeFunc) (OutputBuffer *, DecoderControl *);
typedef MpdTag * (* InputPlugin_tagDupFunc) (char * utf8file);
typedef struct _InputPlugin {
- char name[INPUT_PLUGIN_NAME_LENGTH];
+ char * name;
InputPlugin_streamDecodeFunc streamDecodeFunc;
InputPlugin_fileDecodeFunc fileDecodeFunc;
InputPlugin_tagDupFunc tagDupFunc;
@@ -28,25 +27,15 @@ typedef struct _InputPlugin {
char ** mimeTypes;
} InputPlugin;
-/* interface for constructing a plugin */
-
-InputPlugin * newInputPlugin(char * name, InputPlugin_streamDecodeFunc
- streamDecodeFunc, InputPlugin_fileDecodeFunc fileDecodeFunc,
- InputPlugin_tagDupFunc tagDupFunc, unsigned char streamTypes);
-void addSuffixToInputPlugin(InputPlugin * inPlugin, char * suffix);
-void addMimeTypeToInputPlugin(InputPlugin * inPlugin, char * suffix);
-void freeInputPlugin(InputPlugin * inputPlugin);
-
/* individual functions to load/unload plugins */
void loadInputPlugin(InputPlugin * inputPlugin);
-/* this free's inputPlugin as well! */
void unloadInputPlugin(InputPlugin * inputPlugin);
/* interface for using plugins */
InputPlugin * getInputPluginFromSuffix(char * suffix);
-InputPlugin * getInputPluginFromMimeTypes(char * mimeType);
+InputPlugin * getInputPluginFromMimeType(char * mimeType);
InputPlugin * getInputPluginFromName(char * name);
diff --git a/src/mp3_decode.c b/src/inputPlugins/mp3_plugin.c
index 467a656df..5d34a1068 100644
--- a/src/mp3_decode.c
+++ b/src/inputPlugins/mp3_plugin.c
@@ -16,28 +16,27 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-#include "mp3_decode.h"
+#include "../inputPlugin.h"
#ifdef HAVE_MAD
-#include "pcm_utils.h"
+#include "../pcm_utils.h"
#ifdef USE_MPD_MAD
-#include "libmad/mad.h"
+#include "../libmad/mad.h"
#else
#include <mad.h>
#endif
#ifdef HAVE_ID3TAG
#ifdef USE_MPD_ID3TAG
-#include "libid3tag/id3tag.h"
+#include "../libid3tag/id3tag.h"
#else
#include <id3tag.h>
#endif
#endif
-#include "playerData.h"
-#include "log.h"
-#include "utils.h"
-#include "inputStream.h"
-#include "outputBuffer.h"
+#include "../log.h"
+#include "../utils.h"
+#include "../tag.h"
+#include "../path.h"
#include <stdio.h>
#include <string.h>
@@ -419,10 +418,10 @@ int getMp3TotalTime(char * file) {
}
int openMp3FromInputStream(InputStream * inStream, mp3DecodeData * data,
- DecoderControl * dc, int ignoreCrc)
+ DecoderControl * dc)
{
initMp3DecodeData(data, inStream);
- if(ignoreCrc) data->stream.options |= MAD_OPTION_IGNORECRC;
+ data->stream.options |= MAD_OPTION_IGNORECRC;
if(decodeFirstFrame(data, dc)<0) {
mp3DecodeDataFinalize(data);
return -1;
@@ -565,12 +564,10 @@ void initAudioFormatFromMp3DecodeData(mp3DecodeData * data, AudioFormat * af) {
af->channels = MAD_NCHANNELS(&(data->frame).header);
}
-int mp3_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream,
- int ignoreCrc)
-{
+int mp3_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream) {
mp3DecodeData data;
- if(openMp3FromInputStream(inStream, &data, dc, ignoreCrc) < 0) {
+ if(openMp3FromInputStream(inStream, &data, dc) < 0) {
closeInputStream(inStream);
if(!dc->stop) {
ERROR("Input does not appear to be a mp3 bit stream.\n");
@@ -616,5 +613,47 @@ int mp3_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream,
return 0;
}
+MpdTag * mp3_tagDup(char * utf8file) {
+ MpdTag * ret = NULL;
+ int time;
+
+ ret = id3Dup(utf8file);
+
+ time = getMp3TotalTime(rmp2amp(utf8ToFsCharset(utf8file)));
+
+ if(time>=0) {
+ if(!ret) ret = newMpdTag();
+ ret->time = time;
+ }
+
+ if(ret) validateUtf8Tag(ret);
+
+ return ret;
+}
+
+char * mp3_suffixes[] = {"mp3", NULL};
+char * mp3_mimeTypes[] = {"audio/mpeg", NULL};
+
+InputPlugin mp3Plugin =
+{
+ "mp3",
+ mp3_decode,
+ NULL,
+ mp3_tagDup,
+ INPUT_PLUGIN_STREAM_FILE | INPUT_PLUGIN_STREAM_URL,
+ mp3_suffixes,
+ mp3_mimeTypes
+};
+#else
+
+InputPlugin mp3Plugin =
+{
+ NULL,
+ NULL,
+ NULL,
+ 0,
+ NULL,
+ NULL
+};
+
#endif
-/* vim:set shiftwidth=8 tabstop=8 expandtab: */
diff --git a/src/ogg_decode.c b/src/inputPlugins/ogg_plugin.c
index 22ae07727..af617378e 100644
--- a/src/ogg_decode.c
+++ b/src/inputPlugins/ogg_plugin.c
@@ -16,18 +16,18 @@
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
-#include "ogg_decode.h"
+#include "../inputPlugin.h"
#ifdef HAVE_OGG
-#include "command.h"
-#include "utils.h"
-#include "audio.h"
-#include "log.h"
-#include "pcm_utils.h"
-#include "inputStream.h"
-#include "outputBuffer.h"
-#include "replayGain.h"
+#include "../command.h"
+#include "../utils.h"
+#include "../audio.h"
+#include "../log.h"
+#include "../pcm_utils.h"
+#include "../inputStream.h"
+#include "../outputBuffer.h"
+#include "../replayGain.h"
#include <stdio.h>
#include <unistd.h>
@@ -274,5 +274,91 @@ int ogg_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream)
return 0;
}
+MpdTag * oggTagDup(char * utf8file) {
+ MpdTag * ret = NULL;
+ FILE * fp;
+ OggVorbis_File vf;
+ char ** comments;
+ char * temp;
+ char * s1;
+ char * s2;
+
+ fp = fopen(rmp2amp(utf8ToFsCharset(utf8file)),"r");
+ if(!fp) return NULL;
+ if(ov_open(fp,&vf,NULL,0)<0) {
+ fclose(fp);
+ return NULL;
+ }
+
+ ret = newMpdTag();
+ ret->time = (int)(ov_time_total(&vf,-1)+0.5);
+
+ comments = ov_comment(&vf,-1)->user_comments;
+
+ while(*comments) {
+ temp = strdup(*comments);
+ ++comments;
+ if(!(s1 = strtok(temp,"="))) continue;
+ s2 = strtok(NULL,"");
+ if(!s1 || !s2);
+ else if(0==strcasecmp(s1,"artist")) {
+ if(!ret->artist) {
+ stripReturnChar(s2);
+ ret->artist = strdup(s2);
+ }
+ }
+ else if(0==strcasecmp(s1,"title")) {
+ if(!ret->title) {
+ stripReturnChar(s2);
+ ret->title = strdup(s2);
+ }
+ }
+ else if(0==strcasecmp(s1,"album")) {
+ if(!ret->album) {
+ stripReturnChar(s2);
+ ret->album = strdup(s2);
+ }
+ }
+ else if(0==strcasecmp(s1,"tracknumber")) {
+ if(!ret->track) {
+ stripReturnChar(s2);
+ ret->track = strdup(s2);
+ }
+ }
+ free(temp);
+ }
+
+ ov_clear(&vf);
+
+ if(ret) validateUtf8Tag(ret);
+
+ return ret;
+}
+
+char * oggSuffixes[] = {"ogg", NULL};
+char * oggMimeTypes[] = {"application/ogg", NULL};
+
+InputPlugin oggPlugin =
+{
+ "ogg",
+ ogg_decode,
+ NULL,
+ oggTagDup,
+ INPUT_PLUGIN_STREAM_URL | INPUT_PLUGIN_STREAM_FILE,
+ oggSuffixes,
+ oggMimeTypes
+};
+
+#else
+
+InputPlugin oggPlugin =
+{
+ NULL,
+ NULL,
+ NULL,
+ 0,
+ NULL,
+ NULL
+};
+
#endif
-/* vim:set shiftwidth=4 tabstop=8 expandtab: */
diff --git a/src/inputStream_http.c b/src/inputStream_http.c
index f60c5240d..ab06a3c89 100644
--- a/src/inputStream_http.c
+++ b/src/inputStream_http.c
@@ -389,10 +389,12 @@ static int getHTTPHello(InputStream * inStream) {
DEBUG("stream audiocast-name: %s\n", data->icyName);
}
else if(0 == strncmp(cur, "\r\nContent-Type:", 15)) {
- char * temp = strstr(cur+15,"\r\n");
+ int incr = 15;
+ char * temp = strstr(cur+incr,"\r\n");
if(!temp) break;
*temp = '\0';
if(inStream->mime) free(inStream->mime);
+ while(*(incr+cur) == ' ') incr++;
inStream->mime = strdup(cur+15);
*temp = '\r';
}
diff --git a/src/ls.c b/src/ls.c
index 52ca5b782..285874585 100644
--- a/src/ls.c
+++ b/src/ls.c
@@ -216,27 +216,15 @@ int isDir(char * utf8name) {
return 0;
}
-int isMusic(char * utf8file, time_t * mtime) {
+InputPlugin * isMusic(char * utf8file, time_t * mtime) {
+ InputPlugin * ret = NULL;
+
if(isFile(utf8file,mtime)) {
-#ifdef HAVE_OGG
- if(hasOggSuffix(utf8file)) return 1;
-#endif
-#ifdef HAVE_FLAC
- if(hasFlacSuffix(utf8file)) return 1;
-#endif
-#ifdef HAVE_MAD
- if(hasMp3Suffix(utf8file)) return 1;
-#endif
-#ifdef HAVE_AUDIOFILE
- if(hasWaveSuffix(utf8file)) return 1;
-#endif
-#ifdef HAVE_FAAD
- if(hasMp4Suffix(utf8file)) return 1;
- if(hasAacSuffix(utf8file)) return 1;
-#endif
+ char * s = getSuffix(utf8file);
+ if(s) ret = getInputPluginFromSuffix(s);
}
- return 0;
+ return ret;
}
/* vim:set shiftwidth=4 tabstop=8 expandtab: */
diff --git a/src/ls.h b/src/ls.h
index cb99df299..ef19676b1 100644
--- a/src/ls.h
+++ b/src/ls.h
@@ -21,11 +21,15 @@
#include "../config.h"
+#include "inputPlugin.h"
+
#include <stdio.h>
#include <time.h>
int lsPlaylists(FILE * fp, char * utf8path);
+char * getSuffix(char * utf8file);
+
int isRemoteUrl(char * url);
int isFile(char * utf8file, time_t * mtime);
@@ -34,19 +38,7 @@ int isDir(char * utf8name);
int isPlaylist(char * utf8file);
-int isMusic(char * utf8file, time_t * mtime);
-
-int hasWaveSuffix(char * utf8file);
-
-int hasMp3Suffix(char * utf8file);
-
-int hasAacSuffix(char * utf8file);
-
-int hasMp4Suffix(char * utf8file);
-
-int hasOggSuffix(char * utf8file);
-
-int hasFlacSuffix(char * utf8file);
+InputPlugin * isMusic(char * utf8file, time_t * mtime);
char * dupAndStripPlaylistSuffix(char * file);
diff --git a/src/main.c b/src/main.c
index c19e80f31..1bbf11531 100644
--- a/src/main.c
+++ b/src/main.c
@@ -33,6 +33,7 @@
#include "log.h"
#include "permission.h"
#include "replayGain.h"
+#include "inputPlugin.h"
#include "../config.h"
#include <stdio.h>
@@ -327,6 +328,7 @@ int main(int argc, char * argv[]) {
initTables();
initPlaylist();
+ initInputPlugins();
if(!options.dbFile) directory_db = strdup(rpp2app(".mpddb"));
else directory_db = strdup(options.dbFile);
@@ -448,6 +450,7 @@ int main(int argc, char * argv[]) {
finishPaths();
finishPermissions();
finishCommands();
+ finishInputPlugins();
return EXIT_SUCCESS;
}
diff --git a/src/mp3_decode.h b/src/mp3_decode.h
deleted file mode 100644
index 7cc1ecfb4..000000000
--- a/src/mp3_decode.h
+++ /dev/null
@@ -1,38 +0,0 @@
-/* the Music Player Daemon (MPD)
- * (c)2003-2004 by Warren Dukes (shank@mercury.chem.pitt.edu)
- * 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 MP3_DECODE_H
-#define MP3_DECODE_H
-
-#include "../config.h"
-
-#ifdef HAVE_MAD
-
-#include "playerData.h"
-#include "inputStream.h"
-
-/* this is primarily used in tag.c */
-int getMp3TotalTime(char * file);
-
-int mp3_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream,
- int ignoreCrc);
-
-#endif
-
-#endif
-/* vim:set shiftwidth=4 tabstop=8 expandtab: */
diff --git a/src/ogg_decode.h b/src/ogg_decode.h
deleted file mode 100644
index 03f1364a5..000000000
--- a/src/ogg_decode.h
+++ /dev/null
@@ -1,34 +0,0 @@
-/* the Music Player Daemon (MPD)
- * (c)2003-2004 by Warren Dukes (shank@mercury.chem.pitt.edu)
- * 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 OGG_DECODE_H
-#define OGG_DECODE_H
-
-#include "../config.h"
-
-#include "playerData.h"
-#include "inputStream.h"
-
-#include <stdio.h>
-
-int ogg_decode(OutputBuffer * cb, DecoderControl * dc, InputStream * inStream);
-
-int getOggTotalTime(char * file);
-
-#endif
-/* vim:set shiftwidth=4 tabstop=8 expandtab: */
diff --git a/src/player.c b/src/player.c
index 82f3101cd..33184f72c 100644
--- a/src/player.c
+++ b/src/player.c
@@ -117,7 +117,6 @@ int playerInit() {
closeMp3Directory();
finishPlaylist();
closeTables();
- finishPaths();
finishPermissions();
finishCommands();
finishVolume();
@@ -160,35 +159,8 @@ int playerInit() {
return 0;
}
-int playerGetDecodeType(char * utf8file) {
- if(isRemoteUrl(utf8file)) return DECODE_TYPE_URL;
- if(isFile(utf8file,NULL)) return DECODE_TYPE_FILE;
- return -1;
-}
-
-int playerGetSuffix(char * utf8file) {
-#ifdef HAVE_MAD
- if(hasMp3Suffix(utf8file)) return DECODE_SUFFIX_MP3;
-#endif
-#ifdef HAVE_OGG
- if(hasOggSuffix(utf8file)) return DECODE_SUFFIX_OGG;
-#endif
-#ifdef HAVE_FAAD
- if(hasAacSuffix(utf8file)) return DECODE_SUFFIX_AAC;
- if(hasMp4Suffix(utf8file)) return DECODE_SUFFIX_MP4;
-#endif
-#ifdef HAVE_FLAC
- if(hasFlacSuffix(utf8file)) return DECODE_SUFFIX_FLAC;
-#endif
-#ifdef HAVE_AUDIOFILE
- if(hasWaveSuffix(utf8file)) return DECODE_SUFFIX_WAVE;
-#endif
- return -1;
-}
-
int playerPlay(FILE * fp, Song * song) {
PlayerControl * pc = &(getPlayerData()->playerControl);
- int decodeType;
if(fp==NULL) fp = stderr;
@@ -204,15 +176,6 @@ int playerPlay(FILE * fp, Song * song) {
}
}*/
- decodeType = playerGetDecodeType(song->utf8url);
- if(decodeType < 0) {
- strncpy(pc->erroredFile,pc->file,MAXPATHLEN);
- pc->erroredFile[MAXPATHLEN] = '\0';
- pc->error = PLAYER_ERROR_UNKTYPE;
- return 0;
- }
- pc->decodeType = decodeType;
- pc->fileSuffix = playerGetSuffix(song->utf8url);
if(song->tag) pc->fileTime = song->tag->time;
else pc->fileTime = 0;
@@ -362,7 +325,6 @@ void playerCloseAudio() {
int queueSong(Song * song) {
PlayerControl * pc = &(getPlayerData()->playerControl);
- int decodeType;
if(pc->queueState==PLAYER_QUEUE_BLANK) {
if(isRemoteUrl(song->utf8url)) {
@@ -372,10 +334,6 @@ int queueSong(Song * song) {
MAXPATHLEN);
pc->file[MAXPATHLEN] = '\0';
- decodeType = playerGetDecodeType(song->utf8url);
- if(decodeType < 0) return -1;
- pc->decodeType = decodeType;
- pc->fileSuffix = playerGetSuffix(song->utf8url);
if(song->tag) pc->fileTime = song->tag->time;
else pc->fileTime = 0;
@@ -421,7 +379,6 @@ void playerQueueUnlock() {
int playerSeek(FILE * fp, Song * song, float time) {
PlayerControl * pc = &(getPlayerData()->playerControl);
char * file;
- int decodeType;
if(pc->state==PLAYER_STATE_STOP) {
myfprintf(fp,"%s player not currently playing\n",
@@ -432,16 +389,6 @@ int playerSeek(FILE * fp, Song * song, float time) {
if(isRemoteUrl(song->utf8url)) file = song->utf8url;
else file = rmp2amp(utf8ToFsCharset(song->utf8url));
if(strcmp(pc->file,file)!=0) {
- decodeType = playerGetDecodeType(song->utf8url);
- if(decodeType < 0) {
- myfprintf(fp,"%s unknown file type: %s\n",
- COMMAND_RESPOND_ERROR, song->utf8url);
- ERROR("playerSeek: unknown file type: %s\n",
- song->utf8url);
- return -1;
- }
- pc->decodeType = decodeType;
- pc->fileSuffix = playerGetSuffix(song->utf8url);
if(song->tag) pc->fileTime = song->tag->time;
else pc->fileTime = 0;
diff --git a/src/player.h b/src/player.h
index a0b5515c1..75bc71edf 100644
--- a/src/player.h
+++ b/src/player.h
@@ -52,8 +52,6 @@
#define PLAYER_QUEUE_LOCKED 1
typedef struct _PlayerControl {
- volatile mpd_sint8 decodeType;
- volatile mpd_sint8 fileSuffix;
volatile mpd_sint8 stop;
volatile mpd_sint8 play;
volatile mpd_sint8 pause;
diff --git a/src/song.c b/src/song.c
index 5991a2612..9d2a09e54 100644
--- a/src/song.c
+++ b/src/song.c
@@ -23,13 +23,10 @@
#include "utils.h"
#include "tag.h"
#include "log.h"
-#include "mp3_decode.h"
-#include "audiofile_decode.h"
-#include "ogg_decode.h"
-#include "flac_decode.h"
#include "path.h"
#include "playlist.h"
#include "tables.h"
+#include "inputPlugin.h"
#define SONG_KEY "key: "
#define SONG_FILE "file: "
@@ -60,36 +57,10 @@ Song * newSong(char * utf8url, SONG_TYPE type) {
song->type = type;
if(song->type == SONG_TYPE_FILE) {
- if(!isFile(utf8url,&(song->mtime)));
-#ifdef HAVE_OGG
- else if(hasOggSuffix(utf8url)) {
- song->tag = oggTagDup(utf8url);
- }
-#endif
-#ifdef HAVE_FLAC
- else if((hasFlacSuffix(utf8url))) {
- song->tag = flacTagDup(utf8url);
- }
-#endif
-#ifdef HAVE_MAD
- else if(hasMp3Suffix(utf8url)) {
- song->tag = mp3TagDup(utf8url);
- }
-#endif
-#ifdef HAVE_AUDIOFILE
- else if(hasWaveSuffix(utf8url)) {
- song->tag = audiofileTagDup(utf8url);
- }
-#endif
-#ifdef HAVE_FAAD
- else if(hasAacSuffix(utf8url)) {
- song->tag = aacTagDup(utf8url);
- }
- else if(hasMp4Suffix(utf8url)) {
- song->tag = mp4TagDup(utf8url);
- }
-#endif
-
+ InputPlugin * plugin;
+ if((plugin = isMusic(utf8url,&(song->mtime)))) {
+ song->tag = plugin->tagDupFunc(utf8url);
+ }
if(!song->tag || song->tag->time<0) {
freeSong(song);
song = NULL;
@@ -288,41 +259,16 @@ int updateSongInfo(Song * song) {
char * utf8url = song->utf8url;
if(song->type == SONG_TYPE_FILE) {
+ InputPlugin * plugin;
+
removeASongFromTables(song);
if(song->tag) freeMpdTag(song->tag);
song->tag = NULL;
- if(!isFile(utf8url,&(song->mtime)));
-#ifdef HAVE_OGG
- else if(hasOggSuffix(utf8url)) {
- song->tag = oggTagDup(utf8url);
- }
-#endif
-#ifdef HAVE_FLAC
- else if((hasFlacSuffix(utf8url))) {
- song->tag = flacTagDup(utf8url);
- }
-#endif
-#ifdef HAVE_MAD
- else if(hasMp3Suffix(utf8url)) {
- song->tag = mp3TagDup(utf8url);
- }
-#endif
-#ifdef HAVE_AUDIOFILE
- else if(hasWaveSuffix(utf8url)) {
- song->tag = audiofileTagDup(utf8url);
- }
-#endif
-#ifdef HAVE_FAAD
- else if(hasAacSuffix(utf8url)) {
- song->tag = aacTagDup(utf8url);
- }
- else if(hasMp4Suffix(utf8url)) {
- song->tag = mp4TagDup(utf8url);
- }
-#endif
-
+ if((plugin = isMusic(utf8url,&(song->mtime)))) {
+ song->tag = plugin->tagDupFunc(utf8url);
+ }
if(!song->tag || song->tag->time<0) return -1;
else addSongToTables(song);
}
diff --git a/src/tag.c b/src/tag.c
index 3a968fe8e..c540fa06e 100644
--- a/src/tag.c
+++ b/src/tag.c
@@ -19,7 +19,6 @@
#include "tag.h"
#include "path.h"
#include "myfprintf.h"
-#include "mp3_decode.h"
#include "audiofile_decode.h"
#include "mp4_decode.h"
#include "aac_decode.h"
@@ -171,26 +170,6 @@ MpdTag * audiofileTagDup(char * utf8file) {
}
#endif
-#ifdef HAVE_MAD
-MpdTag * mp3TagDup(char * utf8file) {
- MpdTag * ret = NULL;
- int time;
-
- ret = id3Dup(utf8file);
-
- time = getMp3TotalTime(rmp2amp(utf8ToFsCharset(utf8file)));
-
- if(time>=0) {
- if(!ret) ret = newMpdTag();
- ret->time = time;
- }
-
- if(ret) validateUtf8Tag(ret);
-
- return ret;
-}
-#endif
-
#ifdef HAVE_FAAD
MpdTag * aacTagDup(char * utf8file) {
MpdTag * ret = NULL;
@@ -300,69 +279,6 @@ MpdTag * mp4TagDup(char * utf8file) {
}
#endif
-#ifdef HAVE_OGG
-MpdTag * oggTagDup(char * utf8file) {
- MpdTag * ret = NULL;
- FILE * fp;
- OggVorbis_File vf;
- char ** comments;
- char * temp;
- char * s1;
- char * s2;
-
- fp = fopen(rmp2amp(utf8ToFsCharset(utf8file)),"r");
- if(!fp) return NULL;
- if(ov_open(fp,&vf,NULL,0)<0) {
- fclose(fp);
- return NULL;
- }
-
- ret = newMpdTag();
- ret->time = (int)(ov_time_total(&vf,-1)+0.5);
-
- comments = ov_comment(&vf,-1)->user_comments;
-
- while(*comments) {
- temp = strdup(*comments);
- ++comments;
- if(!(s1 = strtok(temp,"="))) continue;
- s2 = strtok(NULL,"");
- if(!s1 || !s2);
- else if(0==strcasecmp(s1,"artist")) {
- if(!ret->artist) {
- stripReturnChar(s2);
- ret->artist = strdup(s2);
- }
- }
- else if(0==strcasecmp(s1,"title")) {
- if(!ret->title) {
- stripReturnChar(s2);
- ret->title = strdup(s2);
- }
- }
- else if(0==strcasecmp(s1,"album")) {
- if(!ret->album) {
- stripReturnChar(s2);
- ret->album = strdup(s2);
- }
- }
- else if(0==strcasecmp(s1,"tracknumber")) {
- if(!ret->track) {
- stripReturnChar(s2);
- ret->track = strdup(s2);
- }
- }
- free(temp);
- }
-
- ov_clear(&vf);
-
- if(ret) validateUtf8Tag(ret);
-
- return ret;
-}
-#endif
-
#ifdef HAVE_FLAC
MpdTag * flacMetadataDup(char * utf8file, int * vorbisCommentFound) {
MpdTag * ret = NULL;
diff --git a/src/tag.h b/src/tag.h
index a406a3cae..89e60adfe 100644
--- a/src/tag.h
+++ b/src/tag.h
@@ -31,6 +31,8 @@ typedef struct _MpdTag {
int time;
} MpdTag;
+MpdTag * id3Dup(char * utf8filename);
+
MpdTag * newMpdTag();
void freeMpdTag(MpdTag * tag);
@@ -61,5 +63,7 @@ void printMpdTag(FILE * fp, MpdTag * tag);
MpdTag * mpdTagDup(MpdTag * tag);
+void validateUtf8Tag(MpdTag * tag);
+
#endif
/* vim:set shiftwidth=4 tabstop=8 expandtab: */