summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 9e94b7c)
raw | patch | inline | side by side (parent: 9e94b7c)
author | Max Kellermann <max@duempel.org> | |
Tue, 16 Sep 2008 17:11:39 +0000 (19:11 +0200) | ||
committer | Max 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.
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 | patch | blob | history | |
src/mpdclient.c | patch | blob | history | |
src/mpdclient.h | patch | blob | history | |
src/playlist.c | [new file with mode: 0644] | patch | blob |
src/playlist.h | [new file with mode: 0644] | patch | blob |
diff --git a/src/Makefile.am b/src/Makefile.am
index 857c97cc21304883a51d22d4cdcb7955758f15a2..21bef4d20d4b09c913346802b385232003d8d74d 100644 (file)
--- a/src/Makefile.am
+++ b/src/Makefile.am
libmpdclient.h\
song.h \
mpdclient.h\
+ playlist.h \
easy_download.h\
options.h\
conf.h\
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 c570051657443aaaa6b65138a9e450c37c8892a8..1d52aebdb196003f375fd91d1b7ba27cf9b04b08 100644 (file)
--- a/src/mpdclient.c
+++ b/src/mpdclient.c
/*** 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
}
#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 f1b993756b2876d353838f6ff8e11fbc1466ce7f..2ce803e86f5f34c42f2717d1bb6d207fa6234cab 100644 (file)
--- a/src/mpdclient.h
+++ b/src/mpdclient.h
#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;
/*** 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
--- /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
--- /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