update: rewrote updatePath() using updateInDirectory()

updatePath() duplicated a lot of code from the more generic
updateInDirectory().  Eliminate most of updatePath() and call
updateInDirectory().
This commit is contained in:
Max Kellermann 2008-10-09 19:13:02 +02:00
parent 7dd099a60f
commit 953f186c8a

View File

@ -148,6 +148,23 @@ delete_song_if_removed(struct song *song, void *_data)
return 0; return 0;
} }
static enum update_return
delete_path(const char *path)
{
struct directory *directory = db_get_directory(path);
struct song *song = db_get_song(path);
if (directory != NULL)
delete_directory(directory);
if (song != NULL)
delete_song(song->parent, song);
return directory == NULL && song == NULL
? UPDATE_RETURN_NOUPDATE
: UPDATE_RETURN_UPDATED;
}
static enum update_return static enum update_return
removeDeletedFromDirectory(char *path_max_tmp, struct directory *directory) removeDeletedFromDirectory(char *path_max_tmp, struct directory *directory)
{ {
@ -384,76 +401,12 @@ addParentPathToDB(const char *utf8path)
static enum update_return updatePath(const char *path) static enum update_return updatePath(const char *path)
{ {
struct directory *directory; struct stat st;
struct directory *parentDirectory;
struct song *song;
time_t mtime;
enum update_return ret = UPDATE_RETURN_NOUPDATE;
char path_max_tmp[MPD_PATH_MAX];
/* if path is in the DB try to update it, or else delete it */ if (myStat(path, &st) < 0)
if ((directory = db_get_directory(path))) { return delete_path(path);
parentDirectory = directory->parent;
/* if this update directory is successfull, we are done */ return updateInDirectory(addParentPathToDB(path), path);
ret = updateDirectory(directory);
if (ret != UPDATE_RETURN_ERROR) {
directory_sort(directory);
return ret;
}
/* if updateDirectory fails, means we should delete it */
else {
LOG("removing directory: %s\n", path);
delete_directory(directory);
ret = UPDATE_RETURN_UPDATED;
/* don't return, path maybe a song now */
}
} else if ((song = db_get_song(path))) {
parentDirectory = song->parent;
if (!parentDirectory->stat
&& statDirectory(parentDirectory) < 0)
return UPDATE_RETURN_NOUPDATE;
/* if this song update is successful, we are done */
else if (!inodeFoundInParent(parentDirectory->parent,
parentDirectory->inode,
parentDirectory->device) &&
isMusic(song_get_url(song, path_max_tmp), &mtime, 0)) {
if (song->mtime == mtime)
return UPDATE_RETURN_NOUPDATE;
else if (song_file_update(song))
return UPDATE_RETURN_UPDATED;
else {
delete_song(parentDirectory, song);
return UPDATE_RETURN_UPDATED;
}
}
/* if updateDirectory fails, means we should delete it */
else {
delete_song(parentDirectory, song);
ret = UPDATE_RETURN_UPDATED;
/* don't return, path maybe a directory now */
}
}
/* path not found in the db, see if it actually exists on the fs.
* Also, if by chance a directory was replaced by a file of the same
* name or vice versa, we need to add it to the db
*/
if (isDir(path) || isMusic(path, NULL, 0)) {
parentDirectory = addParentPathToDB(path);
if (!parentDirectory || (!parentDirectory->stat &&
statDirectory(parentDirectory) < 0)) {
} else if (0 == inodeFoundInParent(parentDirectory->parent,
parentDirectory->inode,
parentDirectory->device)
&& updateInDirectory(parentDirectory, path)
== UPDATE_RETURN_UPDATED) {
ret = UPDATE_RETURN_UPDATED;
}
}
return ret;
} }
static void * update_task(void *_path) static void * update_task(void *_path)