diff options
author | Brad King <brad.king@kitware.com> | 2006-05-20 22:50:27 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2006-05-20 22:50:27 (GMT) |
commit | 3dd70af5a0114ec8708c2ab06be647277a3067ac (patch) | |
tree | 16e7744d82376e1e4a24a5e1f2857b5589e90a84 | |
parent | f3ba74a4013e1c9444d03414e15201edc273366a (diff) | |
download | CMake-3dd70af5a0114ec8708c2ab06be647277a3067ac.zip CMake-3dd70af5a0114ec8708c2ab06be647277a3067ac.tar.gz CMake-3dd70af5a0114ec8708c2ab06be647277a3067ac.tar.bz2 |
ENH: Enabling process tree killing on Cygwin.
-rw-r--r-- | Source/kwsys/ProcessUNIX.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/Source/kwsys/ProcessUNIX.c b/Source/kwsys/ProcessUNIX.c index 0f4d1bc..9eedad0 100644 --- a/Source/kwsys/ProcessUNIX.c +++ b/Source/kwsys/ProcessUNIX.c @@ -1909,12 +1909,15 @@ static pid_t kwsysProcessFork(kwsysProcess* cp, #elif defined(__hpux) || defined(__sparc) || defined(__sgi) || defined(_AIX) # define KWSYSPE_PS_COMMAND "ps -ef" # define KWSYSPE_PS_FORMAT "%*s %d %d %*[^\n]\n" +#elif defined(__CYGWIN__) +# define KWSYSPE_PS_COMMAND "ps aux" +# define KWSYSPE_PS_FORMAT "%d %d %*[^\n]\n" #endif /*--------------------------------------------------------------------------*/ static void kwsysProcessKill(pid_t process_id) { -#if defined(__linux__) +#if defined(__linux__) || defined(__CYGWIN__) DIR* procdir; #endif @@ -1922,7 +1925,7 @@ static void kwsysProcessKill(pid_t process_id) kill(process_id, SIGSTOP); /* Kill all children if we can find them. */ -#if defined(__linux__) +#if defined(__linux__) || defined(__CYGWIN__) /* First try using the /proc filesystem. */ if((procdir = opendir("/proc")) != NULL) { @@ -1980,8 +1983,8 @@ static void kwsysProcessKill(pid_t process_id) } else #endif -#if defined(KWSYSPE_PS_COMMAND) { +#if defined(KWSYSPE_PS_COMMAND) /* Try running "ps" to get the process information. */ FILE* ps = popen(KWSYSPE_PS_COMMAND, "r"); @@ -2005,8 +2008,8 @@ static void kwsysProcessKill(pid_t process_id) { pclose(ps); } - } #endif + } /* Kill the process. */ kill(process_id, SIGKILL); |