Code

mpdclient: moved code to playlist.c
authorMax Kellermann <max@duempel.org>
Tue, 16 Sep 2008 17:11:39 +0000 (19:11 +0200)
committerMax Kellermann <max@duempel.org>
Tue, 16 Sep 2008 17:11:39 +0000 (19:11 +0200)
Move everything which manipulates the mpdclient_playlist struct to
playlist.c.  Many of the functions get a mpdclient pointer instead of
a playlist; this will be changed later.

The functions mpdclient_playlist_update() and
mpdclient_playlist_update_changes() stay in mpdclient.c for now, since
they are tightly connected to the client code.

src/Makefile.am
src/mpdclient.c
src/mpdclient.h
src/playlist.c [new file with mode: 0644]
src/playlist.h [new file with mode: 0644]

index 857c97cc21304883a51d22d4cdcb7955758f15a2..21bef4d20d4b09c913346802b385232003d8d74d 100644 (file)
@@ -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\
index c570051657443aaaa6b65138a9e450c37c8892a8..1d52aebdb196003f375fd91d1b7ba27cf9b04b08 100644 (file)
@@ -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 *****************************************************/
index f1b993756b2876d353838f6ff8e11fbc1466ce7f..2ce803e86f5f34c42f2717d1bb6d207fa6234cab 100644 (file)
@@ -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 && \
  (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 (file)
index 0000000..e253043
--- /dev/null
@@ -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 (file)
index 0000000..2d2a353
--- /dev/null
@@ -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