diff options
| author | Mikhail Glushenkov <foldr@codedgers.com> | 2009-09-08 19:50:55 +0000 |
|---|---|---|
| committer | Mikhail Glushenkov <foldr@codedgers.com> | 2009-09-08 19:50:55 +0000 |
| commit | f9e2f241df621bcf8a71055306ecbafefef14eb4 (patch) | |
| tree | 1beef50dd5fea262f4ebd06f41b95bfb363e436d /llvm/lib/System | |
| parent | 4a91b7605b41c4677097e970005ba3a7d045032f (diff) | |
| download | bcm5719-llvm-f9e2f241df621bcf8a71055306ecbafefef14eb4.tar.gz bcm5719-llvm-f9e2f241df621bcf8a71055306ecbafefef14eb4.zip | |
Get rid of the Pid_ member in the Program class.
llvm-svn: 81247
Diffstat (limited to 'llvm/lib/System')
| -rw-r--r-- | llvm/lib/System/Unix/Program.inc | 17 | ||||
| -rw-r--r-- | llvm/lib/System/Win32/Program.inc | 32 |
2 files changed, 29 insertions, 20 deletions
diff --git a/llvm/lib/System/Unix/Program.inc b/llvm/lib/System/Unix/Program.inc index fdd0c25fd14..ce757105f88 100644 --- a/llvm/lib/System/Unix/Program.inc +++ b/llvm/lib/System/Unix/Program.inc @@ -34,10 +34,14 @@ namespace llvm { using namespace sys; -Program::Program() : Pid_(0) {} +Program::Program() : Data_(0) {} Program::~Program() {} +unsigned Program::GetPid() { + return reinterpret_cast<unsigned>(Data_); +} + // This function just uses the PATH environment variable to find the program. Path Program::FindProgramByName(const std::string& progName) { @@ -209,7 +213,7 @@ Program::Execute(const Path& path, break; } - Pid_ = child; + Data_ = reinterpret_cast<void*>(child); return true; } @@ -221,7 +225,7 @@ Program::Wait(unsigned secondsToWait, #ifdef HAVE_SYS_WAIT_H struct sigaction Act, Old; - if (Pid_ == 0) { + if (Data_ == 0) { MakeErrMsg(ErrMsg, "Process not started!"); return -1; } @@ -237,7 +241,7 @@ Program::Wait(unsigned secondsToWait, // Parent process: Wait for the child process to terminate. int status; - int child = this->Pid_; + pid_t child = reinterpret_cast<pid_t>(Data_); while (wait(&status) != child) if (secondsToWait && errno == EINTR) { // Kill the child. @@ -285,12 +289,13 @@ Program::Wait(unsigned secondsToWait, bool Program::Kill(std::string* ErrMsg) { - if (Pid_ == 0) { + if (Data_ == 0) { MakeErrMsg(ErrMsg, "Process not started!"); return true; } - return (kill(Pid_, SIGKILL) == 0); + pid_t pid = reinterpret_cast<pid_t>(Data_); + return (kill(pid, SIGKILL) == 0); } bool Program::ChangeStdinToBinary(){ diff --git a/llvm/lib/System/Win32/Program.inc b/llvm/lib/System/Win32/Program.inc index 4f4b6b32b1d..b23fdce7825 100644 --- a/llvm/lib/System/Win32/Program.inc +++ b/llvm/lib/System/Win32/Program.inc @@ -25,16 +25,21 @@ namespace llvm { using namespace sys; -Program::Program() : Pid_(0), Data(0) {} +Program::Program() : Data_(0) {} Program::~Program() { - if (Data) { - HANDLE hProcess = (HANDLE) Data; + if (Data_) { + HANDLE hProcess = reinterpret_cast<HANDLE>(Data_); CloseHandle(hProcess); - Data = 0; + Data_ = 0; } } +unsigned Program::GetPid() { + HANDLE hProcess = reinterpret_cast<HANDLE>(Data_); + return GetProcessId(hProcess); +} + // This function just uses the PATH environment variable to find the program. Path Program::FindProgramByName(const std::string& progName) { @@ -132,10 +137,10 @@ Program::Execute(const Path& path, const Path** redirects, unsigned memoryLimit, std::string* ErrMsg) { - if (Data) { - HANDLE hProcess = (HANDLE) Data; - CloseHandle(Data); - Data = 0; + if (Data_) { + HANDLE hProcess = reinterpret_cast<HANDLE>(Data_); + CloseHandle(Data_); + Data_ = 0; } if (!path.canExecute()) { @@ -264,8 +269,7 @@ Program::Execute(const Path& path, path.str() + "'"); return false; } - Pid_ = pi.dwProcessId; - Data = pi.hProcess; + Data_ = reinterpret_cast<void*>(pi.hProcess); // Make sure these get closed no matter what. AutoHandle hThread(pi.hThread); @@ -301,12 +305,12 @@ Program::Execute(const Path& path, int Program::Wait(unsigned secondsToWait, std::string* ErrMsg) { - if (Data == 0) { + if (Data_ == 0) { MakeErrMsg(ErrMsg, "Process not started!"); return -1; } - HANDLE hProcess = (HANDLE) Data; + HANDLE hProcess = reinterpret_cast<HANDLE>(Data_); // Wait for the process to terminate. DWORD millisecondsToWait = INFINITE; @@ -337,12 +341,12 @@ Program::Wait(unsigned secondsToWait, bool Program::Kill(std::string* ErrMsg) { - if (Data == 0) { + if (Data_ == 0) { MakeErrMsg(ErrMsg, "Process not started!"); return true; } - HANDLE hProcess = reinterpret_cast<HANDLE>(Data); + HANDLE hProcess = reinterpret_cast<HANDLE>(Data_); return TerminateProcess(hProcess, 1); } |

