X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f6bcfd974ef26faf6f91a62cac09827e09463fd1..5d91e653c5f2683eb21485d6b5c1e5f286ab5e11:/src/common/process.cpp?ds=sidebyside diff --git a/src/common/process.cpp b/src/common/process.cpp index 5a3f23843a..05e24ffb20 100644 --- a/src/common/process.cpp +++ b/src/common/process.cpp @@ -9,6 +9,14 @@ // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// +// ============================================================================ +// declarations +// ============================================================================ + +// ---------------------------------------------------------------------------- +// headers +// ---------------------------------------------------------------------------- + #ifdef __GNUG__ #pragma implementation "process.h" #endif @@ -20,15 +28,25 @@ #pragma hdrstop #endif -#ifndef WX_PRECOMP - #include "wx/defs.h" -#endif - #include "wx/process.h" +// ---------------------------------------------------------------------------- +// event tables and such +// ---------------------------------------------------------------------------- + +DEFINE_EVENT_TYPE(wxEVT_END_PROCESS) + IMPLEMENT_DYNAMIC_CLASS(wxProcess, wxEvtHandler) IMPLEMENT_DYNAMIC_CLASS(wxProcessEvent, wxEvent) +// ============================================================================ +// wxProcess implementation +// ============================================================================ + +// ---------------------------------------------------------------------------- +// wxProcess creation +// ---------------------------------------------------------------------------- + void wxProcess::Init(wxEvtHandler *parent, int id, bool redirect) { if ( parent ) @@ -44,6 +62,10 @@ void wxProcess::Init(wxEvtHandler *parent, int id, bool redirect) #endif // wxUSE_STREAMS } +// ---------------------------------------------------------------------------- +// wxProcess termination +// ---------------------------------------------------------------------------- + wxProcess::~wxProcess() { #if wxUSE_STREAMS @@ -68,6 +90,10 @@ void wxProcess::Detach() SetNextHandler(NULL); } +// ---------------------------------------------------------------------------- +// process IO redirection +// ---------------------------------------------------------------------------- + #if wxUSE_STREAMS void wxProcess::SetPipeStreams(wxInputStream *inputSstream, @@ -80,3 +106,37 @@ void wxProcess::SetPipeStreams(wxInputStream *inputSstream, } #endif // wxUSE_STREAMS + +// ---------------------------------------------------------------------------- +// process killing +// ---------------------------------------------------------------------------- + +/* static */ +wxKillError wxProcess::Kill(int pid, wxSignal sig) +{ + wxKillError rc; + (void)wxKill(pid, sig, &rc); + + return rc; +} + +/* static */ +bool wxProcess::Exists(int pid) +{ + switch ( Kill(pid, wxSIGNONE) ) + { + case wxKILL_OK: + case wxKILL_ACCESS_DENIED: + return TRUE; + + default: + case wxKILL_ERROR: + case wxKILL_BAD_SIGNAL: + wxFAIL_MSG( _T("unexpected wxProcess::Kill() return code") ); + // fall through + + case wxKILL_NO_PROCESS: + return FALSE; + } +} +