]> git.sesse.net Git - vlc/commitdiff
signals: ignore SIGHUP if its handler is SIG_IGN
authorRémi Denis-Courmont <remi@remlab.net>
Tue, 8 Dec 2009 21:13:39 +0000 (23:13 +0200)
committerRémi Denis-Courmont <remi@remlab.net>
Tue, 8 Dec 2009 21:13:39 +0000 (23:13 +0200)
This works around GNU coreutils nohup not working with VLC.

Pointed-out-by: Gilles Chanteperdrix <gilles.chanteperdrix@xenomai.org>
modules/control/signals.c

index 7acf926808b0dfade8b513c72a07c794e8126e25..5cb6f369b94437bc5a6c552a3829464ea5b54e11 100644 (file)
@@ -84,6 +84,16 @@ static void Close (vlc_object_t *obj)
     free (p_sys);
 }
 
+static bool ignored (int signum)
+{
+    struct sigaction sa;
+
+    if (sigaction (signum, NULL, &sa))
+        return false;
+    return ((sa.sa_flags & SA_SIGINFO)
+            ? (void *)sa.sa_sigaction : (void *)sa.sa_handler) == SIG_IGN;
+}
+
 static void *SigThread (void *data)
 {
     intf_thread_t *obj = data;
@@ -91,7 +101,8 @@ static void *SigThread (void *data)
     int signum;
 
     sigemptyset (&set);
-    sigaddset (&set, SIGHUP);
+    if (!ignored (SIGHUP)) /* <- needed to handle nohup properly */
+        sigaddset (&set, SIGHUP);
     sigaddset (&set, SIGINT);
     sigaddset (&set, SIGQUIT);
     sigaddset (&set, SIGTERM);