diff options
author | Eric Wong <normalperson@yhbt.net> | 2008-09-28 20:29:40 -0700 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2008-09-28 20:30:58 -0700 |
commit | 887f97b868886a66d7bb2fcd0e1fd6810297299d (patch) | |
tree | 7a4f050b0905fb5d0b645dfdb623dcc4fbc36852 | |
parent | e7203ca8349f03c5364a97b9dee68a83e4d506dc (diff) | |
download | mpd-887f97b868886a66d7bb2fcd0e1fd6810297299d.tar.gz mpd-887f97b868886a66d7bb2fcd0e1fd6810297299d.tar.xz mpd-887f97b868886a66d7bb2fcd0e1fd6810297299d.zip |
clean up updateInit calling and error handling
Move error reporting to command.c so directory.c does not deal
with client error handling any more.
-rw-r--r-- | src/command.c | 20 | ||||
-rw-r--r-- | src/directory.c | 12 | ||||
-rw-r--r-- | src/directory.h | 3 |
3 files changed, 22 insertions, 13 deletions
diff --git a/src/command.c b/src/command.c index 616132bea..ce41abb64 100644 --- a/src/command.c +++ b/src/command.c @@ -799,6 +799,16 @@ static int handlePlaylistMove(int fd, mpd_unused int *permission, return print_playlist_result(fd, result); } +static int print_update_result(int fd, int ret) +{ + if (ret >= 0) { + fdprintf(fd, "updating_db: %i\n", ret); + return 0; + } + commandError(fd, ACK_ERROR_UPDATE_ALREADY, "already updating"); + return -1; +} + static int listHandleUpdate(int fd, mpd_unused int *permission, mpd_unused int argc, @@ -818,7 +828,7 @@ static int listHandleUpdate(int fd, nextCmd = getCommandEntryFromString(next->data, permission); if (cmd != nextCmd) - return updateInit(fd, pathList); + return print_update_result(fd, updateInit(pathList)); return 0; } @@ -826,12 +836,14 @@ static int listHandleUpdate(int fd, static int handleUpdate(int fd, mpd_unused int *permission, mpd_unused int argc, char *argv[]) { + List *pathList = NULL; + if (argc == 2) { - List *pathList = makeList(NULL, 1); + pathList = makeList(NULL, 1); insertInList(pathList, argv[1], NULL); - return updateInit(fd, pathList); } - return updateInit(fd, NULL); + + return print_update_result(fd, updateInit(pathList)); } static int handleNext(mpd_unused int fd, mpd_unused int *permission, diff --git a/src/directory.c b/src/directory.c index 124ea194e..a332316ff 100644 --- a/src/directory.c +++ b/src/directory.c @@ -18,7 +18,6 @@ #include "directory.h" -#include "command.h" #include "conf.h" #include "log.h" #include "ls.h" @@ -148,14 +147,13 @@ out: return (void *)ret; } -int updateInit(int fd, List * path_list) +int updateInit(List * path_list) { pthread_attr_t attr; - if (progress != UPDATE_PROGRESS_IDLE) { - commandError(fd, ACK_ERROR_UPDATE_ALREADY, "already updating"); + if (progress != UPDATE_PROGRESS_IDLE) return -1; - } + progress = UPDATE_PROGRESS_RUNNING; pthread_attr_init(&attr); @@ -166,9 +164,7 @@ int updateInit(int fd, List * path_list) directory_updateJobId = 1; DEBUG("updateInit: spawned update thread for update job id %i\n", (int)directory_updateJobId); - fdprintf(fd, "updating_db: %i\n", (int)directory_updateJobId); - - return 0; + return directory_updateJobId; } static void directory_set_stat(Directory * dir, const struct stat *st) diff --git a/src/directory.h b/src/directory.h index 5c4c76a25..9161efc38 100644 --- a/src/directory.h +++ b/src/directory.h @@ -42,7 +42,8 @@ void reap_update_task(void); int isUpdatingDB(void); -int updateInit(int fd, List * pathList); +/* returns the non-negative update job ID on success, -1 on error */ +int updateInit(List * pathList); void directory_init(void); |