]> git.ipfire.org Git - thirdparty/shairport-sync.git/commitdiff
activity monitor should send an active_end on shutdown, provided it was in the active...
authorMike Brady <4265913+mikebrady@users.noreply.github.com>
Wed, 21 Jun 2023 18:24:18 +0000 (19:24 +0100)
committerMike Brady <4265913+mikebrady@users.noreply.github.com>
Wed, 21 Jun 2023 18:24:18 +0000 (19:24 +0100)
activity_monitor.c

index 49f99d134e79bf81bcd269fcfddc67a0fdca691e..361bf517c0c7a677ac2371ed460620fac29be1f3 100644 (file)
@@ -50,6 +50,7 @@ enum am_state state;
 enum ps_state { ps_inactive, ps_active } player_state;
 
 int activity_monitor_running = 0;
+int activity_monitor_is_shutting_down = 0;
 
 pthread_t activity_monitor_thread;
 pthread_mutex_t activity_monitor_mutex;
@@ -120,7 +121,7 @@ void activity_monitor_signify_activity(int active) {
     pthread_mutex_unlock(&activity_monitor_mutex);
     going_active(config.cmd_blocking);
   } else if ((state == am_active) && (player_state == ps_inactive) &&
-             (config.active_state_timeout == 0.0)) {
+             ((config.active_state_timeout == 0.0) || (activity_monitor_is_shutting_down != 0))) {
     state = am_inactive;
     pthread_mutex_unlock(&activity_monitor_mutex);
     going_inactive(config.cmd_blocking);
@@ -240,7 +241,9 @@ void activity_monitor_start() {
 
 void activity_monitor_stop() {
   if (activity_monitor_running) {
+    activity_monitor_is_shutting_down = 1;
     debug(3, "activity_monitor_stop start...");
+    activity_monitor_signify_activity(0); // tell it to go inactive...
     pthread_cancel(activity_monitor_thread);
     pthread_join(activity_monitor_thread, NULL);
     debug(2, "activity_monitor_stop complete");