aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorEric Wong <normalperson@yhbt.net>2008-09-28 19:02:27 -0700
committerEric Wong <normalperson@yhbt.net>2008-09-28 19:02:27 -0700
commitd645f0a97a52ac061d1f6a43b798c05df93fc48e (patch)
treeea811b2c7ac230c61e3b8def8cce192e0361a441 /src
parent54df40c5f96eb8fe80b50dd8a85e8045c7dac9d4 (diff)
downloadmpd-d645f0a97a52ac061d1f6a43b798c05df93fc48e.tar.gz
mpd-d645f0a97a52ac061d1f6a43b798c05df93fc48e.tar.xz
mpd-d645f0a97a52ac061d1f6a43b798c05df93fc48e.zip
directory: update playlist version if updated
If we updated the mpd metadata database; then there's a chance some of those songs in the playlist will have updated metadata. So be on the safe side and increment the playlist version number if _any_ song changed (this is how all released versions of mpd did it, too). This bug was introduced recently when making "update" threaded. Thanks to stonecrest for the bug report.
Diffstat (limited to 'src')
-rw-r--r--src/directory.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/directory.c b/src/directory.c
index ca6ef8666..f7c426267 100644
--- a/src/directory.c
+++ b/src/directory.c
@@ -123,9 +123,14 @@ int isUpdatingDB(void)
void reap_update_task(void)
{
+ enum update_return ret;
+
if (progress != UPDATE_PROGRESS_DONE)
return;
- pthread_join(update_thr, NULL);
+ if (pthread_join(update_thr, (void **)&ret))
+ FATAL("error joining update thread: %s\n", strerror(errno));
+ if (ret == UPDATE_RETURN_UPDATED)
+ playlistVersionChange();
progress = UPDATE_PROGRESS_IDLE;
}