X-Git-Url: https://git.distorted.org.uk/~mdw/disorder/blobdiff_plain/219dc95cf771d5ba07aa19a3b33002a649682060..ced93033b2d27cbba04c2044ad428c12943892bb:/disobedience/log.c diff --git a/disobedience/log.c b/disobedience/log.c index d8dbe35..83aa582 100644 --- a/disobedience/log.c +++ b/disobedience/log.c @@ -41,6 +41,7 @@ static void log_removed(void *v, const char *id, const char *user); static void log_scratched(void *v, const char *track, const char *user); static void log_state(void *v, unsigned long state); static void log_volume(void *v, int l, int r); +static void log_rescanned(void *v); /** @brief Callbacks for server state monitoring */ const disorder_eclient_log_callbacks log_callbacks = { @@ -55,7 +56,8 @@ const disorder_eclient_log_callbacks log_callbacks = { log_removed, log_scratched, log_state, - log_volume + log_volume, + log_rescanned }; /** @brief State monitor @@ -81,10 +83,10 @@ static struct monitor *monitors; /** @brief Update everything */ void all_update(void) { - playing_update(); queue_update(); recent_update(); volume_update(); + added_update(); } /** @brief Called when the client connects @@ -105,16 +107,12 @@ static void log_connected(void attribute((unused)) *v) { /** @brief Called when the current track finishes playing */ static void log_completed(void attribute((unused)) *v, const char attribute((unused)) *track) { - playing = 0; - playing_update(); } /** @brief Called when the current track fails */ static void log_failed(void attribute((unused)) *v, const char attribute((unused)) *track, const char attribute((unused)) *status) { - playing = 0; - playing_update(); } /** @brief Called when some track is moved within the queue */ @@ -126,10 +124,6 @@ static void log_moved(void attribute((unused)) *v, static void log_playing(void attribute((unused)) *v, const char attribute((unused)) *track, const char attribute((unused)) *user) { - playing = 1; - playing_update(); - /* we get a log_removed() anyway so we don't need to update_queue() from - * here */ } /** @brief Called when a track is added to the queue */ @@ -157,6 +151,7 @@ static void log_recent_removed(void attribute((unused)) *v, static void log_removed(void attribute((unused)) *v, const char attribute((unused)) *id, const char attribute((unused)) *user) { + queue_update(); } @@ -164,8 +159,6 @@ static void log_removed(void attribute((unused)) *v, static void log_scratched(void attribute((unused)) *v, const char attribute((unused)) *track, const char attribute((unused)) *user) { - playing = 0; - playing_update(); } /** @brief Called when a state change occurs */ @@ -189,10 +182,6 @@ static void log_state(void attribute((unused)) *v, if(changes & m->mask) m->callback(m->u); } - /* If the track is paused or resume then the currently playing track is - * refetched so that we can continue to correctly calculate the played so-far - * field */ - playing_update(); } /** @brief Called when volume changes */ @@ -205,7 +194,18 @@ static void log_volume(void attribute((unused)) *v, } } -/** @brief Add a monitor to the list */ +/** @brief Called when a rescan completes */ +static void log_rescanned(void attribute((unused)) *v) { + added_update(); +} + +/** @brief Add a monitor to the list + * @param callback Function to call + * @param u User data to pass to @p callback + * @param mask Mask of flags that @p callback cares about + * + * Pass @p mask as -1UL to match all flags. + */ void register_monitor(monitor_callback *callback, void *u, unsigned long mask) {