]> git.saurik.com Git - wxWidgets.git/commitdiff
Add flags parameter to wx.Process.Kill and wx.Kill
authorRobin Dunn <robin@alldunn.com>
Tue, 7 Dec 2004 17:56:22 +0000 (17:56 +0000)
committerRobin Dunn <robin@alldunn.com>
Tue, 7 Dec 2004 17:56:22 +0000 (17:56 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@30888 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

wxPython/src/__misc_rename.i
wxPython/src/_process.i

index 318cf77849ed7fcfdafc4a20467d2ea7ab189335..d6fe464ea5c813ff6987cfb61d69bf9bd7f8cc08 100644 (file)
 %rename(KILL_ACCESS_DENIED)                 wxKILL_ACCESS_DENIED;
 %rename(KILL_NO_PROCESS)                    wxKILL_NO_PROCESS;
 %rename(KILL_ERROR)                         wxKILL_ERROR;
+%rename(KILL_NOCHILDREN)                    wxKILL_NOCHILDREN;
+%rename(KILL_CHILDREN)                      wxKILL_CHILDREN;
 %rename(SIGNONE)                            wxSIGNONE;
 %rename(SIGHUP)                             wxSIGHUP;
 %rename(SIGINT)                             wxSIGINT;
 %rename(EXEC_NOHIDE)                        wxEXEC_NOHIDE;
 %rename(EXEC_MAKE_GROUP_LEADER)             wxEXEC_MAKE_GROUP_LEADER;
 %rename(Execute)                            wxExecute;
+%rename(Kill)                               wxKill;
 %rename(JOYSTICK1)                          wxJOYSTICK1;
 %rename(JOYSTICK2)                          wxJOYSTICK2;
 %rename(JOY_BUTTON_ANY)                     wxJOY_BUTTON_ANY;
index dffe60ec6f83358960af657883850776128d0596..52f778d4938faf494745b81301d170b26574fb22 100644 (file)
@@ -39,6 +39,13 @@ enum wxKillError
     wxKILL_ERROR            // another, unspecified error
 };
 
+enum wxKillFlags
+{
+    wxKILL_NOCHILDREN = 0,  // don't kill children
+    wxKILL_CHILDREN = 1     // kill children
+};
+
+
 enum wxSignal
 {
     wxSIGNONE = 0,  // verify if the process exists under Unix
@@ -74,7 +81,9 @@ IMP_PYCALLBACK_VOID_INTINT( wxPyProcess, wxProcess, OnTerminate);
 %name(Process)class wxPyProcess : public wxEvtHandler {
 public:
     // kill the process with the given PID
-    static wxKillError Kill(int pid, wxSignal sig = wxSIGTERM);
+    static wxKillError Kill(int pid,
+                            wxSignal sig = wxSIGTERM,
+                            int flags = wxKILL_NOCHILDREN);
 
     // test if the given process exists
     static bool Exists(int pid);
@@ -166,6 +175,18 @@ long wxExecute(const wxString& command,
                wxPyProcess *process = NULL);
 
 
+
+%typemap(in,numinputs=0) wxKillError* rc ( wxKillError temp ) { $1 = &temp; }
+%typemap(argout) wxKillError* rc 
+{
+    PyObject* o;
+    o = PyInt_FromLong((long) (*$1));
+    $result = t_output_helper($result, o);
+}
+
+int wxKill(long pid, wxSignal sig = wxSIGTERM, wxKillError* rc, int flags = wxKILL_NOCHILDREN);
+
+
 //---------------------------------------------------------------------------
 %init %{
     wxPyPtrTypeMap_Add("wxProcess", "wxPyProcess");