aboutsummaryrefslogtreecommitdiffstats
path: root/src/playlist.h
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2008-09-16 19:11:40 +0200
committerMax Kellermann <max@duempel.org>2008-09-16 19:11:40 +0200
commit4d01c183b4c1e4c51dff3d9aeec1c01ce13a4323 (patch)
tree10d4c33914aed3a30600b804af698f12c93f718a /src/playlist.h
parent3ac0e9238308d8acea506fc95679fe8d5ae44f45 (diff)
downloadmpd-4d01c183b4c1e4c51dff3d9aeec1c01ce13a4323.tar.gz
mpd-4d01c183b4c1e4c51dff3d9aeec1c01ce13a4323.tar.xz
mpd-4d01c183b4c1e4c51dff3d9aeec1c01ce13a4323.zip
use GPtrArray instead of GArray for playlist songs
Diffstat (limited to 'src/playlist.h')
-rw-r--r--src/playlist.h16
1 files changed, 7 insertions, 9 deletions
diff --git a/src/playlist.h b/src/playlist.h
index 377ed84a2..9cd88ab27 100644
--- a/src/playlist.h
+++ b/src/playlist.h
@@ -37,7 +37,7 @@ typedef struct mpdclient_playlist {
gboolean updated;
/* the list */
- GArray *list;
+ GPtrArray *list;
} mpdclient_playlist_t;
void
@@ -70,14 +70,13 @@ playlist_get(const struct mpdclient_playlist *playlist, guint idx)
{
assert(idx < playlist_length(playlist));
- return g_array_index(playlist->list, struct mpd_song *, idx);
+ return g_ptr_array_index(playlist->list, idx);
}
static inline void
playlist_append(struct mpdclient_playlist *playlist, const mpd_Song *song)
{
- mpd_Song *song2 = mpd_songDup(song);
- g_array_append_val(playlist->list, song2);
+ g_ptr_array_add(playlist->list, mpd_songDup(song));
}
static inline void
@@ -86,7 +85,7 @@ playlist_set(const struct mpdclient_playlist *playlist, guint idx,
{
assert(idx < playlist_length(playlist));
- g_array_index(playlist->list, mpd_Song *, idx) = mpd_songDup(song);
+ g_ptr_array_index(playlist->list, idx) = mpd_songDup(song);
}
static inline void
@@ -100,9 +99,8 @@ playlist_replace(struct mpdclient_playlist *playlist, guint idx,
static inline void
playlist_remove(struct mpdclient_playlist *playlist, guint idx)
{
- mpd_Song *song = playlist_get(playlist, idx);
+ mpd_Song *song = g_ptr_array_remove_index(playlist->list, idx);
mpd_freeSong(song);
- g_array_remove_index(playlist->list, idx);
}
static inline void
@@ -118,8 +116,8 @@ playlist_swap(struct mpdclient_playlist *playlist, guint idx1, guint idx2)
song2->pos = n;
/* update the array */
- g_array_index(playlist->list, struct mpd_song *, idx1) = song2;
- g_array_index(playlist->list, struct mpd_song *, idx2) = song1;
+ g_ptr_array_index(playlist->list, idx1) = song2;
+ g_ptr_array_index(playlist->list, idx2) = song1;
}
struct mpd_song *playlist_lookup_song(struct mpdclient *c, gint id);