diff options
author | Max Kellermann <max@duempel.org> | 2008-10-09 15:37:21 +0200 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2008-10-11 19:21:49 -0700 |
commit | 8fabdfadaf2be72c5af9fd2b9804caf3cd0d14de (patch) | |
tree | 9670fbf7e48848f354fb1f2695cc778233fcfbf4 /src | |
parent | f5edfa1a93af9a8692d45d076a2f45cc25d33d94 (diff) | |
download | mpd-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.c | 48 |
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; } |