aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/Makefile.am2
-rw-r--r--src/mpdclient.c82
-rw-r--r--src/mpdclient.h33
-rw-r--r--src/playlist.c113
-rw-r--r--src/playlist.h55
5 files changed, 174 insertions, 111 deletions
diff --git a/src/Makefile.am b/src/Makefile.am
index 857c97cc2..21bef4d20 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -16,6 +16,7 @@ ncmpc_headers = \
libmpdclient.h\
song.h \
mpdclient.h\
+ playlist.h \
easy_download.h\
options.h\
conf.h\
@@ -45,6 +46,7 @@ ncmpc_SOURCES = \
song.c \
main.c\
mpdclient.c\
+ playlist.c \
options.c\
conf.c\
command.c\
diff --git a/src/mpdclient.c b/src/mpdclient.c
index c57005165..1d52aebdb 100644
--- a/src/mpdclient.c
+++ b/src/mpdclient.c
@@ -647,20 +647,6 @@ mpdclient_remove_error_callback(mpdclient_t *c, mpdc_error_cb_t cb)
/*** Playlist managment functions *******************************************/
/****************************************************************************/
-gint
-mpdclient_playlist_free(mpdclient_playlist_t *playlist)
-{
- guint i;
-
- for (i = 0; i < playlist->list->len; ++i) {
- struct mpd_song *song = g_array_index(playlist->list, struct mpd_song *, i);
- mpd_freeSong(song);
- }
-
- g_array_free(playlist->list, TRUE);
- memset(playlist, 0, sizeof(mpdclient_playlist_t));
- return 0;
-}
/* update playlist */
gint
@@ -759,74 +745,6 @@ mpdclient_playlist_update_changes(mpdclient_t *c)
}
#endif
-struct mpd_song *
-playlist_get_song(mpdclient_t *c, gint idx)
-{
- if (idx < 0 || (guint)idx >= c->playlist.list->len)
- return NULL;
-
- return g_array_index(c->playlist.list, struct mpd_song *, idx);
-}
-
-struct mpd_song *
-playlist_lookup_song(mpdclient_t *c, gint id)
-{
- guint i;
-
- for (i = 0; i < c->playlist.list->len; ++i) {
- struct mpd_song *song = g_array_index(c->playlist.list,
- struct mpd_song *, i);
- if (song->id == id)
- return song;
- }
-
- return NULL;
-}
-
-gint
-playlist_get_index(mpdclient_t *c, struct mpd_song *song)
-{
- guint i;
-
- for (i = 0; i < c->playlist.list->len; ++i) {
- if (g_array_index(c->playlist.list, struct mpd_song *, i)
- == song)
- return (gint)i;
- }
-
- return -1;
-}
-
-gint
-playlist_get_index_from_id(mpdclient_t *c, gint id)
-{
- guint i;
-
- for (i = 0; i < c->playlist.list->len; ++i) {
- struct mpd_song *song = g_array_index(c->playlist.list,
- struct mpd_song *, i);
- if (song->id == id)
- return (gint)i;
- }
-
- return -1;
-}
-
-gint
-playlist_get_index_from_file(mpdclient_t *c, gchar *filename)
-{
- guint i;
-
- for (i = 0; i < c->playlist.list->len; ++i) {
- struct mpd_song *song = g_array_index(c->playlist.list,
- struct mpd_song *, i);
- if(strcmp(song->file, filename) == 0)
- return (gint)i;
- }
-
- return -1;
-}
-
/****************************************************************************/
/*** Filelist functions *****************************************************/
diff --git a/src/mpdclient.h b/src/mpdclient.h
index f1b993756..2ce803e86 100644
--- a/src/mpdclient.h
+++ b/src/mpdclient.h
@@ -2,8 +2,7 @@
#define MPDCLIENT_H
#include "libmpdclient.h"
-
-#include <glib.h>
+#include "playlist.h"
#define MPD_VERSION_EQ(c,x,y,z) (c->connection->version[0] == x && \
c->connection->version[1] == y && \
@@ -14,22 +13,6 @@
(c->connection->version[0]==x && c->connection->version[1]==y && \
c->connection->version[2]<z) )
-
-
-/****************************************************************************/
-/* Playlist */
-/****************************************************************************/
-
-typedef struct mpdclient_playlist {
- /* playlist id */
- long long id;
- /* true if the list is updated */
- gboolean updated;
- /* the list */
- GArray *list;
-
-} mpdclient_playlist_t;
-
typedef struct filelist_entry {
guint flags;
mpd_InfoEntity *entity;
@@ -120,19 +103,11 @@ void mpdclient_remove_error_callback(mpdclient_t *c, mpdc_error_cb_t cb);
/*** playlist functions **************************************************/
-/* free a playlist */
-gint mpdclient_playlist_free(mpdclient_playlist_t *playlist);
/* update the complete playlist */
-gint mpdclient_playlist_update(mpdclient_t *c);
-/* get playlist changes */
-gint mpdclient_playlist_update_changes(mpdclient_t *c);
-
-struct mpd_song *playlist_lookup_song(mpdclient_t *c, gint id);
-struct mpd_song *playlist_get_song(mpdclient_t *c, gint index);
-gint playlist_get_index(mpdclient_t *c, struct mpd_song *song);
-gint playlist_get_index_from_id(mpdclient_t *c, gint id);
-gint playlist_get_index_from_file(mpdclient_t *c, gchar *filename);
+gint mpdclient_playlist_update(struct mpdclient *c);
+/* get playlist changes */
+gint mpdclient_playlist_update_changes(struct mpdclient *c);
/*** mpdclient playlist callbacks *****************************************/
diff --git a/src/playlist.c b/src/playlist.c
new file mode 100644
index 000000000..e2530435e
--- /dev/null
+++ b/src/playlist.c
@@ -0,0 +1,113 @@
+/*
+ * $Id$
+ *
+ * (c) 2004 by Kalle Wallin <kaw@linux.se>
+ * (c) 2008 Max Kellermann <max@duempel.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 "playlist.h"
+#include "mpdclient.h"
+#include "ncmpc.h"
+
+#include <string.h>
+
+#define ENABLE_PLCHANGES
+
+#define MPD_ERROR(c) (c==NULL || c->connection==NULL || c->connection->error)
+
+gint
+mpdclient_playlist_free(mpdclient_playlist_t *playlist)
+{
+ guint i;
+
+ for (i = 0; i < playlist->list->len; ++i) {
+ struct mpd_song *song = g_array_index(playlist->list, struct mpd_song *, i);
+ mpd_freeSong(song);
+ }
+
+ g_array_free(playlist->list, TRUE);
+ memset(playlist, 0, sizeof(mpdclient_playlist_t));
+ return 0;
+}
+
+struct mpd_song *
+playlist_get_song(mpdclient_t *c, gint idx)
+{
+ if (idx < 0 || (guint)idx >= c->playlist.list->len)
+ return NULL;
+
+ return g_array_index(c->playlist.list, struct mpd_song *, idx);
+}
+
+struct mpd_song *
+playlist_lookup_song(mpdclient_t *c, gint id)
+{
+ guint i;
+
+ for (i = 0; i < c->playlist.list->len; ++i) {
+ struct mpd_song *song = g_array_index(c->playlist.list,
+ struct mpd_song *, i);
+ if (song->id == id)
+ return song;
+ }
+
+ return NULL;
+}
+
+gint
+playlist_get_index(mpdclient_t *c, struct mpd_song *song)
+{
+ guint i;
+
+ for (i = 0; i < c->playlist.list->len; ++i) {
+ if (g_array_index(c->playlist.list, struct mpd_song *, i)
+ == song)
+ return (gint)i;
+ }
+
+ return -1;
+}
+
+gint
+playlist_get_index_from_id(mpdclient_t *c, gint id)
+{
+ guint i;
+
+ for (i = 0; i < c->playlist.list->len; ++i) {
+ struct mpd_song *song = g_array_index(c->playlist.list,
+ struct mpd_song *, i);
+ if (song->id == id)
+ return (gint)i;
+ }
+
+ return -1;
+}
+
+gint
+playlist_get_index_from_file(mpdclient_t *c, gchar *filename)
+{
+ guint i;
+
+ for (i = 0; i < c->playlist.list->len; ++i) {
+ struct mpd_song *song = g_array_index(c->playlist.list,
+ struct mpd_song *, i);
+ if(strcmp(song->file, filename) == 0)
+ return (gint)i;
+ }
+
+ return -1;
+}
diff --git a/src/playlist.h b/src/playlist.h
new file mode 100644
index 000000000..2d2a353a6
--- /dev/null
+++ b/src/playlist.h
@@ -0,0 +1,55 @@
+/*
+ * $Id$
+ *
+ * (c) 2004 by Kalle Wallin <kaw@linux.se>
+ * (c) 2008 Max Kellermann <max@duempel.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 MPDCLIENT_PLAYLIST_H
+#define MPDCLIENT_PLAYLIST_H
+
+#include "libmpdclient.h"
+
+#include <glib.h>
+
+struct mpdclient;
+
+typedef struct mpdclient_playlist {
+ /* playlist id */
+ long long id;
+
+ /* true if the list is updated */
+ gboolean updated;
+
+ /* the list */
+ GArray *list;
+} mpdclient_playlist_t;
+
+/* free a playlist */
+gint mpdclient_playlist_free(mpdclient_playlist_t *playlist);
+
+struct mpd_song *playlist_lookup_song(struct mpdclient *c, gint id);
+
+struct mpd_song *playlist_get_song(struct mpdclient *c, gint index);
+
+gint playlist_get_index(struct mpdclient *c, struct mpd_song *song);
+
+gint playlist_get_index_from_id(struct mpdclient *c, gint id);
+
+gint playlist_get_index_from_file(struct mpdclient *c, gchar *filename);
+
+#endif