1998-07-03 13:44:34 -04:00
|
|
|
\section{\class{wxProcess}}\label{wxprocess}
|
|
|
|
|
1999-06-15 16:42:48 -04:00
|
|
|
The objects of this class are used in conjunction with
|
1999-02-17 12:56:59 -05:00
|
|
|
\helpref{wxExecute}{wxexecute} function. When a wxProcess object is passed to
|
|
|
|
wxExecute(), its \helpref{OnTerminate()}{wxprocessonterminate} virtual method
|
|
|
|
is called when the process terminates. This allows the program to be
|
|
|
|
(asynchronously) notified about the process termination and also retrieve its
|
|
|
|
exit status which is unavailable from wxExecute() in the case of
|
|
|
|
asynchronous execution.
|
|
|
|
|
|
|
|
Please note that if the process termination notification is processed by the
|
|
|
|
parent, it is responsible for deleting the wxProcess object which sent it.
|
|
|
|
However, if it is not processed, the object will delete itself and so the
|
|
|
|
library users should only delete those objects whose notifications have been
|
|
|
|
processed (and call \helpref{Detach()}{wxprocessdetach} for others).
|
1998-07-03 13:44:34 -04:00
|
|
|
|
|
|
|
\wxheading{Derived from}
|
|
|
|
|
|
|
|
\helpref{wxEvtHandler}{wxevthandler}
|
|
|
|
|
1999-02-15 15:41:29 -05:00
|
|
|
\wxheading{Include files}
|
|
|
|
|
|
|
|
<wx/process.h>
|
|
|
|
|
1998-07-03 13:44:34 -04:00
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
|
|
|
\membersection{wxProcess::wxProcess}\label{wxprocessconstr}
|
|
|
|
|
2000-03-05 14:03:21 -05:00
|
|
|
\func{}{wxProcess}{\param{wxEvtHandler *}{ parent = NULL}, \param{int}{ id = -1}}
|
1998-07-03 13:44:34 -04:00
|
|
|
|
|
|
|
Constructs a process object. {\it id} is only used in the case you want to
|
1998-09-06 10:43:36 -04:00
|
|
|
use wxWindows events. It identifies this object, or another window that will
|
|
|
|
receive the event.
|
1998-07-03 13:44:34 -04:00
|
|
|
|
1999-02-17 12:56:59 -05:00
|
|
|
If the {\it parent} parameter is different from NULL, it will receive
|
|
|
|
a wxEVT\_END\_PROCESS notification event (you should insert EVT\_END\_PROCESS
|
|
|
|
macro in the event table of the parent to handle it) with the given {\it id}.
|
|
|
|
|
1998-07-03 13:44:34 -04:00
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{parent}{The event handler parent.}
|
|
|
|
|
|
|
|
\docparam{id}{id of an event.}
|
|
|
|
|
|
|
|
\membersection{wxProcess::\destruct{wxProcess}}
|
|
|
|
|
|
|
|
\func{}{\destruct{wxProcess}}{\void}
|
|
|
|
|
|
|
|
Destroys the wxProcess object.
|
|
|
|
|
1999-02-17 12:56:59 -05:00
|
|
|
\membersection{wxProcess::Detach}\label{wxprocessdetach}
|
|
|
|
|
|
|
|
\func{void}{Detach}{\void}
|
|
|
|
|
|
|
|
Normally, a wxProcess object is deleted by its parent when it receives the
|
|
|
|
notification about the process termination. However, it might happen that the
|
|
|
|
parent object is destroyed before the external process is terminated (e.g. a
|
|
|
|
window from which this external process was launched is closed by the user)
|
|
|
|
and in this case it {\bf should not delete} the wxProcess object, but
|
|
|
|
{\bf should call Detach()} instead. After the wxProcess object is detached
|
|
|
|
from its parent, no notification events will be sent to the parent and the
|
|
|
|
object will delete itself upon reception of the process termination
|
|
|
|
notification.
|
|
|
|
|
2000-03-03 13:46:12 -05:00
|
|
|
\membersection{wxProcess::GetInputStream}\label{wxprocessgetinputstream}
|
|
|
|
|
|
|
|
\constfunc{wxInputStream* }{GetInputStream}{\void}
|
|
|
|
|
2000-03-10 11:06:33 -05:00
|
|
|
It returns a output stream corresponding to the input stream of the subprocess.
|
2000-03-05 14:03:21 -05:00
|
|
|
If it is NULL, you have not turned on the redirection.
|
|
|
|
See \helpref{wxProcess::Redirect}{wxprocessredirect}.
|
2000-03-03 13:46:12 -05:00
|
|
|
|
2000-03-10 11:06:33 -05:00
|
|
|
\membersection{wxProcess::GetOutputStream}\label{wxprocessgetoutputstream}
|
2000-03-03 13:46:12 -05:00
|
|
|
|
2000-03-10 11:06:33 -05:00
|
|
|
\constfunc{wxOutputStream* }{GetOutputStream}{\void}
|
2000-03-03 13:46:12 -05:00
|
|
|
|
2000-03-10 11:06:33 -05:00
|
|
|
It returns an output stream correspoding to the output stream of the subprocess.
|
2000-03-05 14:03:21 -05:00
|
|
|
If it is NULL, you have not turned on the redirection.
|
|
|
|
See \helpref{wxProcess::Redirect}{wxprocessredirect}.
|
2000-03-03 13:46:12 -05:00
|
|
|
|
1998-07-03 13:44:34 -04:00
|
|
|
\membersection{wxProcess::OnTerminate}\label{wxprocessonterminate}
|
|
|
|
|
1999-02-17 12:56:59 -05:00
|
|
|
\constfunc{void}{OnTerminate}{\param{int}{ pid}, \param{int}{ status}}
|
1998-07-03 13:44:34 -04:00
|
|
|
|
|
|
|
It is called when the process with the pid {\it pid} finishes.
|
|
|
|
It raises a wxWindows event when it isn't overriden.
|
|
|
|
|
1999-02-17 12:56:59 -05:00
|
|
|
\docparam{pid}{The pid of the process which has just terminated.}
|
|
|
|
|
|
|
|
\docparam{status}{The exit code of the process.}
|
1998-09-06 10:43:36 -04:00
|
|
|
|
2000-03-05 14:03:21 -05:00
|
|
|
\membersection{wxProcess::Redirect}\label{wxprocessredirect}
|
|
|
|
|
|
|
|
\func{void}{Redirect}{\void}
|
|
|
|
|
|
|
|
It turns on the redirection, wxExecute will try to open a couple of pipes
|
|
|
|
to catch the subprocess stdio. The caught input stream is returned by
|
|
|
|
GetOutputStream() as a non-seekable stream. The caught output stream is returned
|
|
|
|
by GetInputStream() as a non-seekable stream.
|
2000-03-10 11:06:33 -05:00
|
|
|
|