X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/50567b69d60faa5a3575a077bb4f98530813c80d..1cc549e58c75763c9f861be71c93be5fd68bd04e:/src/common/process.cpp diff --git a/src/common/process.cpp b/src/common/process.cpp index e57f66688b..4ef1fb157a 100644 --- a/src/common/process.cpp +++ b/src/common/process.cpp @@ -6,7 +6,7 @@ // Created: 24/06/98 // RCS-ID: $Id$ // Copyright: (c) Guilhem Lavaux -// Licence: wxWindows license +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// // ============================================================================ @@ -17,7 +17,7 @@ // headers // ---------------------------------------------------------------------------- -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "process.h" #endif @@ -47,13 +47,13 @@ IMPLEMENT_DYNAMIC_CLASS(wxProcessEvent, wxEvent) // wxProcess creation // ---------------------------------------------------------------------------- -void wxProcess::Init(wxEvtHandler *parent, int id, bool redirect) +void wxProcess::Init(wxEvtHandler *parent, int id, int flags) { if ( parent ) SetNextHandler(parent); m_id = id; - m_redirect = redirect; + m_redirect = (flags & wxPROCESS_REDIRECT) != 0; #if wxUSE_STREAMS m_inputStream = NULL; @@ -62,6 +62,21 @@ void wxProcess::Init(wxEvtHandler *parent, int id, bool redirect) #endif // wxUSE_STREAMS } +/* static */ +wxProcess *wxProcess::Open(const wxString& cmd, int flags) +{ + wxASSERT_MSG( !(flags & wxEXEC_SYNC), wxT("wxEXEC_SYNC should not be used." )); + wxProcess *process = new wxProcess(wxPROCESS_REDIRECT); + if ( !wxExecute(cmd, flags, process) ) + { + // couldn't launch the process + delete process; + return NULL; + } + + return process; +} + // ---------------------------------------------------------------------------- // wxProcess termination // ---------------------------------------------------------------------------- @@ -105,6 +120,21 @@ void wxProcess::SetPipeStreams(wxInputStream *inputSstream, m_outputStream = outputStream; } +bool wxProcess::IsInputOpened() const +{ + return m_inputStream && m_inputStream->GetLastError() != wxSTREAM_EOF; +} + +bool wxProcess::IsInputAvailable() const +{ + return m_inputStream && m_inputStream->CanRead(); +} + +bool wxProcess::IsErrorAvailable() const +{ + return m_errorStream && m_errorStream->CanRead(); +} + #endif // wxUSE_STREAMS // ---------------------------------------------------------------------------- @@ -123,11 +153,11 @@ wxKillError wxProcess::Kill(int pid, wxSignal sig) /* static */ bool wxProcess::Exists(int pid) { - switch ( wxProcess::Kill(pid, wxSIGNONE) ) + switch ( Kill(pid, wxSIGNONE) ) { case wxKILL_OK: case wxKILL_ACCESS_DENIED: - return TRUE; + return true; default: case wxKILL_ERROR: @@ -136,7 +166,7 @@ bool wxProcess::Exists(int pid) // fall through case wxKILL_NO_PROCESS: - return FALSE; + return false; } }