Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Also display the backtrace on Ctrl-C (use Ctrl-C Ctrl-C to quit)
authormquinson <mquinson@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Thu, 6 Jul 2006 17:38:30 +0000 (17:38 +0000)
committermquinson <mquinson@48e7efb5-ca39-0410-a469-dd3cf9ba447f>
Thu, 6 Jul 2006 17:38:30 +0000 (17:38 +0000)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/simgrid/simgrid/trunk@2494 48e7efb5-ca39-0410-a469-dd3cf9ba447f

src/gras/gras.c

index 576f2d7..28a5ead 100644 (file)
@@ -27,6 +27,17 @@ static void gras_sigusr_handler(int sig) {
    INFO0("SIGUSR1 received. Display the backtrace");
    xbt_backtrace_display();
 }
+
+static void gras_sigint_handler(int sig) {
+   static double lastone = 0;
+   if (lastone == 0 || gras_os_time() - lastone > 5) {
+      lastone = gras_os_time();
+      xbt_backtrace_display();
+      fprintf(stderr,"\nBacktrace displayed because Ctrl-C was pressed. Press again (within 5 sec) to abort the process.\n");
+   } else {
+      exit(1);
+   }
+}
 #endif
 
 void gras_init(int *argc,char **argv) {
@@ -59,6 +70,7 @@ void gras_init(int *argc,char **argv) {
     gras_datadesc_init();
 #if defined(HAVE_SIGNAL) && defined(HAVE_SIGNAL_H)
     signal(SIGUSR1,gras_sigusr_handler);
+    signal(SIGINT,gras_sigint_handler);
 #endif     
   }
 }