]> sjero.net Git - wget/commitdiff
Use sigprocmask instead of sigsetmask.
authorGiuseppe Scrivano <gscrivano@gnu.org>
Thu, 11 Aug 2011 12:23:39 +0000 (14:23 +0200)
committerGiuseppe Scrivano <gscrivano@gnu.org>
Thu, 11 Aug 2011 12:23:39 +0000 (14:23 +0200)
ChangeLog
bootstrap.conf
src/ChangeLog
src/utils.c

index ef6c4bd9410e0d2a8bd4a5ff490f9d0b77a2c91f..6372d51e313c46795bc3bf77a3d4f5ff3296ee66 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,7 @@
 2011-08-11  Giuseppe Scrivano  <gscrivano@gnu.org>
 
+       * bootstrap.conf (gnulib_modules): Add `sigprocmask'.
+
        * configure.ac: Do not hardcode GNU TLS and OpenSSL libraries.
 
        * bootstrap.conf (gnulib_modules): Include module iconv.
index e30c93b44f628003dbbcdf68010f70832725214e..9753d9dc342206fecd126a815378ae8626cf93ac 100644 (file)
@@ -56,6 +56,7 @@ recv
 select
 send
 setsockopt
+sigprocmask
 sigpipe
 snprintf
 socket
index 7e877da3873186c88a05fd4b56f6cbf11a780c2a..9bd7e8892ac408c3eb00dd0ff7588f7722120a12 100644 (file)
@@ -1,5 +1,8 @@
 2011-08-11  Giuseppe Scrivano  <gscrivano@gnu.org>
 
+       * utils.c (abort_run_with_timeout): Use sigprocmask instead of
+       sigsetmask.
+
        * gnutls.c (ssl_connect_wget): Remove call to deprecated function
        `gnutls_certificate_type_set_priority'.
 
index a43671057085906ef2520cad78c2d58395edc170..7d4834fba4e42bc93549d6fe2aec8e04f6a13ca1 100644 (file)
@@ -1930,9 +1930,10 @@ abort_run_with_timeout (int sig)
   /* We don't have siglongjmp to preserve the set of blocked signals;
      if we longjumped out of the handler at this point, SIGALRM would
      remain blocked.  We must unblock it manually. */
-  int mask = siggetmask ();
-  mask &= ~sigmask (SIGALRM);
-  sigsetmask (mask);
+  sigset_t set;
+  sigemptyset (&set);
+  sigaddset (&set, SIGALRM);
+  sigprocmask (SIG_BLOCK, &set, NULL);
 
   /* Now it's safe to longjump. */
   longjmp (run_with_timeout_env, -1);