]>
Commit | Line | Data |
---|---|---|
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 | ||
24 | enum | |
25 | { | |
26 | // no redirection | |
27 | wxPROCESS_DEFAULT = 0, | |
28 | ||
29 | // redirect the IO of the child process | |
30 | wxPROCESS_REDIRECT = 1 | |
31 | }; | |
32 | ||
33 | enum 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 | ||
42 | enum wxSignal | |
43 | { | |
44 | wxSIGNONE = 0, // verify if the process exists under Unix | |
45 | wxSIGHUP, | |
46 | wxSIGINT, | |
47 | wxSIGQUIT, | |
48 | wxSIGILL, | |
49 | wxSIGTRAP, | |
50 | wxSIGABRT, | |
51 | wxSIGIOT = wxSIGABRT, // another name | |
52 | wxSIGEMT, | |
53 | wxSIGFPE, | |
54 | wxSIGKILL, | |
55 | wxSIGBUS, | |
56 | wxSIGSEGV, | |
57 | wxSIGSYS, | |
58 | wxSIGPIPE, | |
59 | wxSIGALRM, | |
60 | wxSIGTERM | |
61 | ||
62 | // further signals are different in meaning between different Unix systems | |
63 | }; | |
64 | ||
65 | ||
66 | //--------------------------------------------------------------------------- | |
67 | ||
68 | ||
69 | %{ | |
70 | IMP_PYCALLBACK_VOID_INTINT( wxPyProcess, wxProcess, OnTerminate); | |
71 | %} | |
72 | ||
73 | ||
74 | %name(Process)class wxPyProcess : public wxEvtHandler { | |
75 | public: | |
76 | // kill the process with the given PID | |
77 | static wxKillError Kill(int pid, wxSignal sig = wxSIGTERM); | |
78 | ||
79 | // test if the given process exists | |
80 | static bool Exists(int pid); | |
81 | ||
82 | // this function replaces the standard popen() one: it launches a process | |
83 | // asynchronously and allows the caller to get the streams connected to its | |
84 | // std{in|out|err} | |
85 | // | |
86 | // on error NULL is returned, in any case the process object will be | |
87 | // deleted automatically when the process terminates and should *not* be | |
88 | // deleted by the caller | |
89 | static wxPyProcess *Open(const wxString& cmd, int flags = wxEXEC_ASYNC); | |
90 | ||
91 | ||
92 | %addtofunc wxPyProcess "self._setCallbackInfo(self, Process)" | |
93 | wxPyProcess(wxEvtHandler *parent = NULL, int id = -1); | |
94 | ||
95 | void _setCallbackInfo(PyObject* self, PyObject* _class); | |
96 | ||
97 | void base_OnTerminate(int pid, int status); | |
98 | ||
99 | // call Redirect before passing the object to wxExecute() to redirect the | |
100 | // launched process stdin/stdout, then use GetInputStream() and | |
101 | // GetOutputStream() to get access to them | |
102 | void Redirect(); | |
103 | bool IsRedirected(); | |
104 | ||
105 | ||
106 | // detach from the parent - should be called by the parent if it's deleted | |
107 | // before the process it started terminates | |
108 | void Detach(); | |
109 | ||
110 | wxInputStream *GetInputStream(); | |
111 | wxInputStream *GetErrorStream(); | |
112 | wxOutputStream *GetOutputStream(); | |
113 | ||
114 | void CloseOutput(); | |
115 | ||
116 | // return True if the child process stdout is not closed | |
117 | bool IsInputOpened() const; | |
118 | ||
119 | // return True if any input is available on the child process stdout/err | |
120 | bool IsInputAvailable() const; | |
121 | bool IsErrorAvailable() const; | |
122 | }; | |
123 | ||
124 | //--------------------------------------------------------------------------- | |
125 | ||
126 | ||
127 | class wxProcessEvent : public wxEvent { | |
128 | public: | |
129 | wxProcessEvent(int id = 0, int pid = 0, int exitcode = 0); | |
130 | int GetPid(); | |
131 | int GetExitCode(); | |
132 | int m_pid, m_exitcode; | |
133 | }; | |
134 | ||
135 | ||
136 | %constant wxEventType wxEVT_END_PROCESS; | |
137 | ||
138 | %pythoncode { | |
139 | EVT_END_PROCESS = wx.PyEventBinder( wxEVT_END_PROCESS, 1 ) | |
140 | } | |
141 | ||
142 | //--------------------------------------------------------------------------- | |
143 | ||
144 | enum | |
145 | { | |
146 | // execute the process asynchronously | |
147 | wxEXEC_ASYNC = 0, | |
148 | ||
149 | // execute it synchronously, i.e. wait until it finishes | |
150 | wxEXEC_SYNC = 1, | |
151 | ||
152 | // under Windows, don't hide the child even if it's IO is redirected (this | |
153 | // is done by default) | |
154 | wxEXEC_NOHIDE = 2, | |
155 | ||
156 | // under Unix, if the process is the group leader then killing -pid kills | |
157 | // all children as well as pid | |
158 | wxEXEC_MAKE_GROUP_LEADER = 4 | |
159 | }; | |
160 | ||
161 | ||
162 | long wxExecute(const wxString& command, | |
163 | int flags = wxEXEC_ASYNC, | |
164 | wxPyProcess *process = NULL); | |
165 | ||
166 | ||
167 | //--------------------------------------------------------------------------- | |
168 | %init %{ | |
169 | wxPyPtrTypeMap_Add("wxProcess", "wxPyProcess"); | |
170 | %} | |
171 | //--------------------------------------------------------------------------- |