aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Wong <normalperson@yhbt.net>2008-10-05 20:13:50 -0700
committerEric Wong <normalperson@yhbt.net>2008-10-05 20:13:50 -0700
commitc344fa6a506d117f1e4c9a6213c5c94937631ff9 (patch)
tree682afaf535c247c6992645694e8749a1a7aa8f60
parent8a2306146149d4d7915ed1346a7dbd908fb1048f (diff)
downloadmpd-c344fa6a506d117f1e4c9a6213c5c94937631ff9.tar.gz
mpd-c344fa6a506d117f1e4c9a6213c5c94937631ff9.tar.xz
mpd-c344fa6a506d117f1e4c9a6213c5c94937631ff9.zip
Assert if we don't have song or song->url set
song objects cannot exist without a path or URL
-rw-r--r--src/directory.c4
-rw-r--r--src/song.c10
2 files changed, 10 insertions, 4 deletions
diff --git a/src/directory.c b/src/directory.c
index 5dbab5018..57a615cbd 100644
--- a/src/directory.c
+++ b/src/directory.c
@@ -296,8 +296,8 @@ removeDeletedFromDirectory(char *path_max_tmp, Directory * directory)
for (i = sv->nr; --i >= 0; ) { /* cleaner deletes if we go backwards */
Song *song = sv->base[i];
- if (!song || !*song->url)
- continue; /* does this happen?, perhaps assert() */
+ assert(song);
+ assert(*song->url);
if (dirname)
sprintf(path_max_tmp, "%s/%s", dirname, song->url);
diff --git a/src/song.c b/src/song.c
index ab98963ad..27f48ad03 100644
--- a/src/song.c
+++ b/src/song.c
@@ -31,8 +31,13 @@
static Song * song_alloc(const char *url, Directory *parent)
{
- size_t urllen = strlen(url);
- Song *song = xmalloc(sizeof(Song) + urllen);
+ size_t urllen;
+ Song *song;
+
+ assert(url);
+ urllen = strlen(url);
+ assert(urllen);
+ song = xmalloc(sizeof(Song) + urllen);
song->tag = NULL;
memcpy(song->url, url, urllen + 1);
@@ -44,6 +49,7 @@ static Song * song_alloc(const char *url, Directory *parent)
Song *newSong(const char *url, Directory * parentDir)
{
Song *song;
+ assert(*url);
if (strchr(url, '\n')) {
DEBUG("newSong: '%s' is not a valid uri\n", url);