aboutsummaryrefslogtreecommitdiffstats
path: root/src/PlaylistUpdate.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'src/PlaylistUpdate.cxx')
-rw-r--r--src/PlaylistUpdate.cxx15
1 files changed, 8 insertions, 7 deletions
diff --git a/src/PlaylistUpdate.cxx b/src/PlaylistUpdate.cxx
index 0e72ef671..52ebefb59 100644
--- a/src/PlaylistUpdate.cxx
+++ b/src/PlaylistUpdate.cxx
@@ -1,5 +1,5 @@
/*
- * Copyright (C) 2003-2013 The Music Player Daemon Project
+ * Copyright (C) 2003-2014 The Music Player Daemon Project
* http://www.musicpd.org
*
* This program is free software; you can redistribute it and/or modify
@@ -22,35 +22,36 @@
#include "DatabaseGlue.hxx"
#include "DatabasePlugin.hxx"
#include "Song.hxx"
+#include "DetachedSong.hxx"
#include "tag/Tag.hxx"
#include "Idle.hxx"
#include "util/Error.hxx"
static bool
-UpdatePlaylistSong(const Database &db, Song &song)
+UpdatePlaylistSong(const Database &db, DetachedSong &song)
{
- if (!song.IsInDatabase() || !song.IsDetached())
+ if (!song.IsInDatabase())
/* only update Songs instances that are "detached"
from the Database */
return false;
- Song *original = db.GetSong(song.uri, IgnoreError());
+ Song *original = db.GetSong(song.GetURI(), IgnoreError());
if (original == nullptr)
/* not found - shouldn't happen, because the update
thread should ensure that all stale Song instances
have been purged */
return false;
- if (original->mtime == song.mtime) {
+ if (original->mtime == song.GetLastModified()) {
/* not modified */
db.ReturnSong(original);
return false;
}
- song.mtime = original->mtime;
+ song.SetLastModified(original->mtime);
if (original->tag != nullptr)
- song.ReplaceTag(Tag(*original->tag));
+ song.SetTag(*original->tag);
db.ReturnSong(original);
return true;