]> git.ipfire.org Git - thirdparty/make.git/commitdiff
Formerly commands.c.~3~
authorRoland McGrath <roland@redhat.com>
Tue, 21 Apr 1992 07:50:13 +0000 (07:50 +0000)
committerRoland McGrath <roland@redhat.com>
Tue, 21 Apr 1992 07:50:13 +0000 (07:50 +0000)
commands.c

index 94097e2a900838019503e768b221a45ed8bf8277..31f43add0bdddfa1501d4de10978b7d768d9c19a 100644 (file)
@@ -367,11 +367,9 @@ fatal_error_signal (sig)
   if (sig == SIGTERM)
     {
       register struct child *c;
-      push_signals_blocked_p (1);
       for (c = children; c != 0; c = c->next)
        if (!c->remote)
          (void) kill (c->pid, SIGTERM);
-      pop_signals_blocked_p ();
     }
 
   /* If we got a signal that means the user
@@ -380,7 +378,6 @@ fatal_error_signal (sig)
   if (PROPAGATED_SIGNAL_MASK & sigmask (sig))
     {
       register struct child *c;
-      push_signals_blocked_p (1);
 
       /* Remote children won't automatically get signals sent
         to the process group, so we must send them.  */
@@ -391,15 +388,15 @@ fatal_error_signal (sig)
       for (c = children; c != 0; c = c->next)
        delete_child_targets (c);
 
-      pop_signals_blocked_p ();
-
       /* Clean up the children.  We don't just use the call below because
         we don't want to print the "Waiting for children" message.  */
-      wait_for_children (0, 0);
+      while (job_slots_used > 0)
+       reap_children (1, 0);
     }
   else
     /* Wait for our children to die.  */
-    wait_for_children (0, 1);
+    while (job_slots_used > 0)
+      reap_children (1, 1);
 
   /* Delete any non-precious intermediate files that were made.  */