diff options
author | Eric Wong <normalperson@yhbt.net> | 2008-10-12 02:06:08 -0700 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2008-10-12 05:27:34 -0700 |
commit | d60f11020f4901b806c822ef5ab2d87bbb9e4077 (patch) | |
tree | 3a50559c65f2cec0a311435acd0818ad96d3ea38 | |
parent | 085d139e21511109b0a38278baf20993c7edfa38 (diff) | |
download | mpd-d60f11020f4901b806c822ef5ab2d87bbb9e4077.tar.gz mpd-d60f11020f4901b806c822ef5ab2d87bbb9e4077.tar.xz mpd-d60f11020f4901b806c822ef5ab2d87bbb9e4077.zip |
update: simplify the serialized_delete usage a bit
Pass a callback and argument to it instead of requiring
explicit type.
-rw-r--r-- | src/update.c | 37 |
1 files changed, 17 insertions, 20 deletions
diff --git a/src/update.c b/src/update.c index 9c0113446..9ede72759 100644 --- a/src/update.c +++ b/src/update.c @@ -46,9 +46,7 @@ static const unsigned update_task_id_max = 1 << 15; static unsigned update_task_id; -enum update_type { UPDATE_TYPE_SONG, UPDATE_TYPE_DIR }; - -static enum update_type delete_type; +static void (*delete_fn)(void *); static void *delete; @@ -66,24 +64,33 @@ static void directory_set_stat(struct directory *dir, const struct stat *st) dir->stat = 1; } -static void serialized_delete(void *del, enum update_type type) +static void serialized_delete(void (*fn)(void *), void *del) { cond_enter(&delete_cond); assert(!delete); - delete_type = type; + assert(!delete_fn); + delete_fn = fn; delete = del; wakeup_main_task(); do { cond_wait(&delete_cond); } while (delete); cond_leave(&delete_cond); } +static void delete_song_safely(struct mpd_song *song) +{ + char tmp[MPD_PATH_MAX]; + LOG("removing: %s\n", song_get_url(song, tmp)); + deleteASongFromPlaylist(song); + song_free(song); +} + static void delete_song(struct directory *dir, struct mpd_song *del) { /* first, prevent traversers in main task from getting this */ songvec_delete(&dir->songs, del); /* now take it out of the playlist (in the main_task) and free */ - serialized_delete(del, UPDATE_TYPE_SONG); + serialized_delete((void (*)(void *))delete_song_safely, del); } /** @@ -97,7 +104,7 @@ static void delete_directory(struct directory *dir) dirvec_delete(&dir->parent->children, dir); /* now we let the main task recursively delete everything under us */ - serialized_delete(dir, UPDATE_TYPE_DIR); + serialized_delete((void (*)(void *))directory_free, dir); } struct delete_data { @@ -408,19 +415,9 @@ void reap_update_task(void) return; cond_enter(&delete_cond); - if (delete) { - switch (delete_type) { - case UPDATE_TYPE_SONG: { - char tmp[MPD_PATH_MAX]; - LOG("removing: %s\n", song_get_url(delete, tmp)); - deleteASongFromPlaylist(delete); - song_free(delete); - } - break; - case UPDATE_TYPE_DIR: - directory_free(delete); - } - delete = NULL; + if (delete && delete_fn) { + delete_fn(delete); + delete = delete_fn = NULL; cond_signal(&delete_cond); } cond_leave(&delete_cond); |