]> git.saurik.com Git - wxWidgets.git/blame - wxPython/src/_process.i
update build and install docs
[wxWidgets.git] / wxPython / src / _process.i
CommitLineData
d14a1e28
RD
1/////////////////////////////////////////////////////////////////////////////
2// Name: _process.i
3// Purpose: SWIG interface stuff for wxProcess and wxExecute
4//
5// Author: Robin Dunn
6//
7// Created: 18-June-1999
8// RCS-ID: $Id$
9// Copyright: (c) 2003 by Total Control Software
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
13// Not a %module
14
15
16//---------------------------------------------------------------------------
17%newgroup
18
19%{
20%}
21
22//---------------------------------------------------------------------------
23
24enum
25{
26 // no redirection
27 wxPROCESS_DEFAULT = 0,
28
29 // redirect the IO of the child process
30 wxPROCESS_REDIRECT = 1
31};
32
33enum wxKillError
34{
35 wxKILL_OK, // no error
36 wxKILL_BAD_SIGNAL, // no such signal
37 wxKILL_ACCESS_DENIED, // permission denied
38 wxKILL_NO_PROCESS, // no such process
39 wxKILL_ERROR // another, unspecified error
40};
41
c1718b2c
RD
42enum wxKillFlags
43{
44 wxKILL_NOCHILDREN = 0, // don't kill children
45 wxKILL_CHILDREN = 1 // kill children
46};
47
48
d14a1e28
RD
49enum wxSignal
50{
51 wxSIGNONE = 0, // verify if the process exists under Unix
52 wxSIGHUP,
53 wxSIGINT,
54 wxSIGQUIT,
55 wxSIGILL,
56 wxSIGTRAP,
57 wxSIGABRT,
58 wxSIGIOT = wxSIGABRT, // another name
59 wxSIGEMT,
60 wxSIGFPE,
61 wxSIGKILL,
62 wxSIGBUS,
63 wxSIGSEGV,
64 wxSIGSYS,
65 wxSIGPIPE,
66 wxSIGALRM,
67 wxSIGTERM
68
69 // further signals are different in meaning between different Unix systems
70};
71
72
73//---------------------------------------------------------------------------
74
75
76%{
77IMP_PYCALLBACK_VOID_INTINT( wxPyProcess, wxProcess, OnTerminate);
78%}
79
80
1b8c7ba6
RD
81%rename(Process) wxPyProcess;
82class wxPyProcess : public wxEvtHandler {
d14a1e28
RD
83public:
84 // kill the process with the given PID
c1718b2c
RD
85 static wxKillError Kill(int pid,
86 wxSignal sig = wxSIGTERM,
87 int flags = wxKILL_NOCHILDREN);
d14a1e28
RD
88
89 // test if the given process exists
90 static bool Exists(int pid);
91
92 // this function replaces the standard popen() one: it launches a process
93 // asynchronously and allows the caller to get the streams connected to its
94 // std{in|out|err}
95 //
96 // on error NULL is returned, in any case the process object will be
97 // deleted automatically when the process terminates and should *not* be
98 // deleted by the caller
99 static wxPyProcess *Open(const wxString& cmd, int flags = wxEXEC_ASYNC);
100
101
2b9048c5 102 %pythonAppend wxPyProcess "self._setCallbackInfo(self, Process)"
d14a1e28
RD
103 wxPyProcess(wxEvtHandler *parent = NULL, int id = -1);
104
105 void _setCallbackInfo(PyObject* self, PyObject* _class);
106
a7a01418
RD
107 void OnTerminate(int pid, int status);
108 %MAKE_BASE_FUNC(Process, OnTerminate);
109
d14a1e28
RD
110 // call Redirect before passing the object to wxExecute() to redirect the
111 // launched process stdin/stdout, then use GetInputStream() and
112 // GetOutputStream() to get access to them
113 void Redirect();
114 bool IsRedirected();
115
116
117 // detach from the parent - should be called by the parent if it's deleted
118 // before the process it started terminates
119 void Detach();
120
121 wxInputStream *GetInputStream();
122 wxInputStream *GetErrorStream();
123 wxOutputStream *GetOutputStream();
124
125 void CloseOutput();
126
dd9f7fea 127 // return True if the child process stdout is not closed
d14a1e28
RD
128 bool IsInputOpened() const;
129
dd9f7fea 130 // return True if any input is available on the child process stdout/err
d14a1e28
RD
131 bool IsInputAvailable() const;
132 bool IsErrorAvailable() const;
7012bb9f
RD
133
134 %property(ErrorStream, GetErrorStream, doc="See `GetErrorStream`");
135 %property(InputStream, GetInputStream, doc="See `GetInputStream`");
136 %property(OutputStream, GetOutputStream, doc="See `GetOutputStream`");
137
138 %property(InputOpened, IsInputOpened);
139 %property(InputAvailable, IsInputAvailable);
140 %property(ErrorAvailable, IsErrorAvailable);
d14a1e28
RD
141};
142
143//---------------------------------------------------------------------------
144
145
146class wxProcessEvent : public wxEvent {
147public:
148 wxProcessEvent(int id = 0, int pid = 0, int exitcode = 0);
149 int GetPid();
150 int GetExitCode();
151 int m_pid, m_exitcode;
7012bb9f
RD
152
153 %property(ExitCode, GetExitCode, doc="See `GetExitCode`");
154 %property(Pid, GetPid, doc="See `GetPid`");
d14a1e28
RD
155};
156
157
158%constant wxEventType wxEVT_END_PROCESS;
159
160%pythoncode {
161EVT_END_PROCESS = wx.PyEventBinder( wxEVT_END_PROCESS, 1 )
162}
163
164//---------------------------------------------------------------------------
165
166enum
167{
168 // execute the process asynchronously
169 wxEXEC_ASYNC = 0,
170
171 // execute it synchronously, i.e. wait until it finishes
172 wxEXEC_SYNC = 1,
173
174 // under Windows, don't hide the child even if it's IO is redirected (this
175 // is done by default)
176 wxEXEC_NOHIDE = 2,
177
178 // under Unix, if the process is the group leader then killing -pid kills
179 // all children as well as pid
9c7e3e86
RD
180 wxEXEC_MAKE_GROUP_LEADER = 4,
181
182 // by default synchronous execution disables all program windows to avoid
183 // that the user interacts with the program while the child process is
184 // running, you can use this flag to prevent this from happening
185 wxEXEC_NODISABLE = 8
d14a1e28
RD
186};
187
188
ab1f7d2a
RD
189MustHaveApp(wxExecute);
190
d14a1e28
RD
191long wxExecute(const wxString& command,
192 int flags = wxEXEC_ASYNC,
193 wxPyProcess *process = NULL);
194
195
c1718b2c
RD
196
197%typemap(in,numinputs=0) wxKillError* rc ( wxKillError temp ) { $1 = &temp; }
198%typemap(argout) wxKillError* rc
199{
200 PyObject* o;
201 o = PyInt_FromLong((long) (*$1));
214c4fbe 202#if SWIG_VERSION < 0x010328
c1718b2c 203 $result = t_output_helper($result, o);
214c4fbe
RD
204#else
205 $result = SWIG_Python_AppendOutput($result, o);
206#endif
c1718b2c
RD
207}
208
209int wxKill(long pid, wxSignal sig = wxSIGTERM, wxKillError* rc, int flags = wxKILL_NOCHILDREN);
210
211
d14a1e28
RD
212//---------------------------------------------------------------------------
213%init %{
214 wxPyPtrTypeMap_Add("wxProcess", "wxPyProcess");
215%}
216//---------------------------------------------------------------------------