]> git.ipfire.org Git - thirdparty/tor.git/commitdiff
catch signals in a more portable way, so solaris can catch them too
authorRoger Dingledine <arma@torproject.org>
Sat, 20 Mar 2004 23:27:22 +0000 (23:27 +0000)
committerRoger Dingledine <arma@torproject.org>
Sat, 20 Mar 2004 23:27:22 +0000 (23:27 +0000)
svn:r1324

src/or/main.c

index 1af6d89810d064239fcb9d5c0b7ad7d4ea574fef..86ea5923e4f808b6378f6ae189c87a0afd9f80da 100644 (file)
@@ -729,7 +729,7 @@ int tor_main(int argc, char *argv[]) {
   if(geteuid()==0)
     log_fn(LOG_WARN,"You are running Tor as root. You don't need to, and you probably shouldn't.");
 #endif
-  
+
   if(options.ORPort) { /* only spawn dns handlers if we're a router */
     dns_init(); /* initialize the dns resolve tree, and spawn workers */
   }
@@ -738,12 +738,19 @@ int tor_main(int argc, char *argv[]) {
   }
 
 #ifndef MS_WINDOWS /* do signal stuff only on unix */
-  signal (SIGINT,  catch); /* catch kills so we can exit cleanly */
-  signal (SIGTERM, catch);
-  signal (SIGPIPE, catch);
-  signal (SIGUSR1, catch); /* to dump stats */
-  signal (SIGHUP,  catch); /* to reload directory */
-  signal (SIGCHLD, catch); /* for exiting dns/cpu workers */
+{
+  struct sigaction action;
+  action.sa_flags = 0;
+  sigemptyset(&action.sa_mask);
+
+  action.sa_handler = catch;
+  sigaction(SIGINT,  &action, NULL);
+  sigaction(SIGTERM, &action, NULL);
+  sigaction(SIGPIPE, &action, NULL);
+  sigaction(SIGUSR1, &action, NULL);
+  sigaction(SIGHUP,  &action, NULL); /* to reload config, retry conns, etc */
+  sigaction(SIGCHLD, &action, NULL); /* handle dns/cpu workers that exit */
+}
 #endif /* signal stuff */
 
   crypto_global_init();