6b70b4633c
cygwin process after waiting 2 tenths of a second for it to terminate. (forcekill): Add an extra argument determining whether to wait for the process to exit.
128 lines
2.3 KiB
C++
128 lines
2.3 KiB
C++
/* kill.cc
|
|
|
|
Copyright 1996, 1997, 1998, 1999, 2000 Red Hat, Inc.
|
|
|
|
This file is part of Cygwin.
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
details. */
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <signal.h>
|
|
#include <string.h>
|
|
#include <time.h>
|
|
#include <errno.h>
|
|
#include <windows.h>
|
|
#include <sys/cygwin.h>
|
|
|
|
static void usage (void);
|
|
static int __stdcall getsig (char *);
|
|
static void __stdcall forcekill (int, int, int);
|
|
|
|
int
|
|
main (int argc, char **argv)
|
|
{
|
|
int sig = SIGTERM;
|
|
int force = 0;
|
|
int gotsig = 0;
|
|
|
|
if (argc == 1)
|
|
usage ();
|
|
|
|
while (*++argv && **argv == '-')
|
|
if (strcmp (*argv + 1, "f") == 0)
|
|
force = 1;
|
|
else if (gotsig)
|
|
break;
|
|
else if (strcmp(*argv + 1, "0") != 0)
|
|
{
|
|
sig = getsig (*argv + 1);
|
|
gotsig = 1;
|
|
}
|
|
else
|
|
{
|
|
argv++;
|
|
sig = 0;
|
|
goto sig0;
|
|
}
|
|
|
|
if (sig <= 0 || sig > NSIG)
|
|
{
|
|
fprintf (stderr, "kill: unknown signal: %s\n", argv[-1]);
|
|
exit (1);
|
|
}
|
|
|
|
sig0:
|
|
while (*argv != NULL)
|
|
{
|
|
char *p;
|
|
int pid = strtol (*argv, &p, 10);
|
|
if (*p != '\0')
|
|
fprintf (stderr, "kill: illegal pid: %s\n", *argv);
|
|
else
|
|
{
|
|
#if 0
|
|
printf ("Sending %s(%d) signal to pid %d\n",
|
|
strsignal (sig), sig, pid);
|
|
#endif
|
|
if (kill (pid, sig) == 0)
|
|
{
|
|
if (force)
|
|
forcekill (pid, sig, 1);
|
|
}
|
|
else
|
|
{
|
|
if (errno == ESRCH && force && sig != 0)
|
|
forcekill (pid, sig, 0);
|
|
else
|
|
{
|
|
char buf[1000];
|
|
sprintf (buf, "kill %d", pid);
|
|
perror (buf);
|
|
}
|
|
}
|
|
}
|
|
argv++;
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
static void
|
|
usage (void)
|
|
{
|
|
fprintf (stderr, "Usage: kill [-sigN] pid1 [pid2 ...]\n");
|
|
exit (1);
|
|
}
|
|
|
|
static int
|
|
getsig (char *in_sig)
|
|
{
|
|
char *sig;
|
|
char buf[80];
|
|
|
|
if (strncmp (in_sig, "SIG", 3) == 0)
|
|
sig = in_sig;
|
|
else
|
|
{
|
|
sprintf (buf, "SIG%s", in_sig);
|
|
sig = buf;
|
|
}
|
|
return (strtosigno (sig) ?: atoi (in_sig));
|
|
}
|
|
|
|
static void __stdcall
|
|
forcekill (int pid, int sig, int wait)
|
|
{
|
|
external_pinfo *p = (external_pinfo *) cygwin_internal (CW_GETPINFO_FULL, pid);
|
|
if (!p)
|
|
return;
|
|
HANDLE h = OpenProcess (PROCESS_TERMINATE, FALSE, (DWORD) p->pid);
|
|
if (!h)
|
|
return;
|
|
if (!wait || WaitForSingleObject (h, 200) != WAIT_OBJECT_0)
|
|
TerminateProcess (h, sig << 8);
|
|
CloseHandle (h);
|
|
}
|