aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2008-10-09 15:37:21 +0200
committerEric Wong <normalperson@yhbt.net>2008-10-11 19:21:49 -0700
commit8fabdfadaf2be72c5af9fd2b9804caf3cd0d14de (patch)
tree9670fbf7e48848f354fb1f2695cc778233fcfbf4 /src
parentf5edfa1a93af9a8692d45d076a2f45cc25d33d94 (diff)
downloadmpd-8fabdfadaf2be72c5af9fd2b9804caf3cd0d14de.tar.gz
mpd-8fabdfadaf2be72c5af9fd2b9804caf3cd0d14de.tar.xz
mpd-8fabdfadaf2be72c5af9fd2b9804caf3cd0d14de.zip
update: removed addToDirectory()
Use updateInDirectory() instead of addToDirectory(). Eliminate a duplicate stat() in updateInDirectory() by calling song_file_update() directly.
Diffstat (limited to 'src')
-rw-r--r--src/update.c48
1 files changed, 10 insertions, 38 deletions
diff --git a/src/update.c b/src/update.c
index b44d07075..355821294 100644
--- a/src/update.c
+++ b/src/update.c
@@ -181,34 +181,6 @@ addSubDirectoryToDirectory(struct directory *directory,
}
static enum update_return
-addToDirectory(struct directory *directory, const char *name)
-{
- struct stat st;
-
- if (myStat(name, &st)) {
- DEBUG("failed to stat %s: %s\n", name, strerror(errno));
- return UPDATE_RETURN_ERROR;
- }
- if (S_ISREG(st.st_mode) &&
- hasMusicSuffix(name, 0) && isMusic(name, NULL, 0)) {
- struct mpd_song *song;
- const char *shortname = mpd_basename(name);
-
- if (!(song = song_file_load(shortname, directory)))
- return -1;
- songvec_add(&directory->songs, song);
- LOG("added %s\n", name);
- return UPDATE_RETURN_UPDATED;
- } else if (S_ISDIR(st.st_mode)) {
- return addSubDirectoryToDirectory(directory, name, &st);
- }
-
- DEBUG("addToDirectory: %s is not a directory or music\n", name);
-
- return UPDATE_RETURN_ERROR;
-}
-
-static enum update_return
updateInDirectory(struct directory *directory, const char *name)
{
struct mpd_song *song;
@@ -221,7 +193,10 @@ updateInDirectory(struct directory *directory, const char *name)
const char *shortname = mpd_basename(name);
if (!(song = songvec_find(&directory->songs, shortname))) {
- addToDirectory(directory, name);
+ if (!(song = song_file_load(shortname, directory)))
+ return -1;
+ songvec_add(&directory->songs, song);
+ LOG("added %s\n", name);
return UPDATE_RETURN_UPDATED;
} else if (st.st_mtime != song->mtime) {
LOG("updating %s\n", name);
@@ -240,6 +215,8 @@ updateInDirectory(struct directory *directory, const char *name)
}
}
+ DEBUG("update: %s is not a directory or music\n", name);
+
return UPDATE_RETURN_NOUPDATE;
}
@@ -285,14 +262,9 @@ enum update_return updateDirectory(struct directory *directory)
if (!isRootDirectory(directory->path))
utf8 = pfx_dir(path_max_tmp, utf8, strlen(utf8),
dirname, strlen(dirname));
- if (was_empty) {
- if (addToDirectory(directory, path_max_tmp) ==
- UPDATE_RETURN_UPDATED)
- ret = UPDATE_RETURN_UPDATED;
- } else {
- if (updateInDirectory(directory, path_max_tmp) > 0)
- ret = UPDATE_RETURN_UPDATED;
- }
+ if (updateInDirectory(directory, path_max_tmp) ==
+ UPDATE_RETURN_UPDATED)
+ ret = UPDATE_RETURN_UPDATED;
}
closedir(dir);
@@ -428,7 +400,7 @@ static enum update_return updatePath(const char *utf8path)
} else if (0 == inodeFoundInParent(parentDirectory->parent,
parentDirectory->inode,
parentDirectory->device)
- && addToDirectory(parentDirectory, utf8path)
+ && updateInDirectory(parentDirectory, utf8path)
== UPDATE_RETURN_UPDATED) {
ret = UPDATE_RETURN_UPDATED;
}