don't use negative PID hack in GUI neither, add a separate flag to wxEndProcessData for this
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@52701 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -15,15 +15,22 @@
|
|||||||
class WXDLLIMPEXP_FWD_BASE wxProcess;
|
class WXDLLIMPEXP_FWD_BASE wxProcess;
|
||||||
class wxStreamTempInputBuffer;
|
class wxStreamTempInputBuffer;
|
||||||
|
|
||||||
// if pid > 0, the execution is async and the data is freed in the callback
|
|
||||||
// executed when the process terminates, if pid < 0, the execution is
|
|
||||||
// synchronous and the caller (wxExecute) frees the data
|
|
||||||
struct wxEndProcessData
|
struct wxEndProcessData
|
||||||
{
|
{
|
||||||
|
wxEndProcessData()
|
||||||
|
{
|
||||||
|
pid =
|
||||||
|
tag =
|
||||||
|
exitcode = -1;
|
||||||
|
process = NULL;
|
||||||
|
async = false;
|
||||||
|
}
|
||||||
|
|
||||||
int pid; // pid of the process
|
int pid; // pid of the process
|
||||||
int tag; // port dependent value
|
int tag; // port dependent value
|
||||||
wxProcess *process; // if !NULL: notified on process termination
|
wxProcess *process; // if !NULL: notified on process termination
|
||||||
int exitcode; // the exit code
|
int exitcode; // the exit code
|
||||||
|
bool async; // if true, delete us on process termination
|
||||||
};
|
};
|
||||||
|
|
||||||
// struct in which information is passed from wxExecute() to wxAppTraits
|
// struct in which information is passed from wxExecute() to wxAppTraits
|
||||||
|
@@ -47,19 +47,13 @@ int wxGUIAppTraits::WaitForChild(wxExecuteData& execData)
|
|||||||
// to process the GUI events while waiting for the child termination
|
// to process the GUI events while waiting for the child termination
|
||||||
|
|
||||||
wxEndProcessData endProcData;
|
wxEndProcessData endProcData;
|
||||||
|
endProcData.pid = execData.pid;
|
||||||
// we may have process for capturing the program output, but it's
|
|
||||||
// not used in wxEndProcessData in the case of sync execution
|
|
||||||
endProcData.process = NULL;
|
|
||||||
|
|
||||||
// sync execution: indicate it by negating the pid
|
|
||||||
endProcData.pid = -execData.pid;
|
|
||||||
|
|
||||||
endProcData.tag = AddProcessCallback
|
endProcData.tag = AddProcessCallback
|
||||||
(
|
(
|
||||||
&endProcData,
|
&endProcData,
|
||||||
execData.GetEndProcReadFD()
|
execData.GetEndProcReadFD()
|
||||||
);
|
);
|
||||||
|
endProcData.async = false;
|
||||||
|
|
||||||
|
|
||||||
// prepare to wait for the child termination: show to the user that we're
|
// prepare to wait for the child termination: show to the user that we're
|
||||||
|
@@ -1412,18 +1412,24 @@ int wxAppTraits::WaitForChild(wxExecuteData& execData)
|
|||||||
{
|
{
|
||||||
if ( !(execData.flags & wxEXEC_SYNC) )
|
if ( !(execData.flags & wxEXEC_SYNC) )
|
||||||
{
|
{
|
||||||
// asynchronous execution: just launch the process and return
|
// asynchronous execution: just launch the process and return,
|
||||||
|
// endProcData will be destroyed when it terminates (currently we leak
|
||||||
|
// it if the process doesn't terminate before we do and this should be
|
||||||
|
// fixed but it's not a real leak so it's not really very high
|
||||||
|
// priority)
|
||||||
wxEndProcessData *endProcData = new wxEndProcessData;
|
wxEndProcessData *endProcData = new wxEndProcessData;
|
||||||
endProcData->process = execData.process;
|
endProcData->process = execData.process;
|
||||||
endProcData->pid = execData.pid;
|
endProcData->pid = execData.pid;
|
||||||
endProcData->tag = AddProcessCallback
|
endProcData->tag = AddProcessCallback
|
||||||
(
|
(
|
||||||
endProcData,
|
endProcData,
|
||||||
execData.GetEndProcReadFD()
|
execData.GetEndProcReadFD()
|
||||||
);
|
);
|
||||||
|
endProcData->async = true;
|
||||||
|
|
||||||
return execData.pid;
|
return execData.pid;
|
||||||
}
|
}
|
||||||
|
//else: synchronous execution case
|
||||||
|
|
||||||
#if wxUSE_STREAMS
|
#if wxUSE_STREAMS
|
||||||
wxProcess * const process = execData.process;
|
wxProcess * const process = execData.process;
|
||||||
@@ -1464,9 +1470,16 @@ void wxHandleProcessTermination(wxEndProcessData *data)
|
|||||||
data->process->OnTerminate(data->pid, data->exitcode);
|
data->process->OnTerminate(data->pid, data->exitcode);
|
||||||
}
|
}
|
||||||
|
|
||||||
// this function is only called for asynchronously executing children, now
|
if ( data->async )
|
||||||
// that we have received the notification about their termination there is
|
{
|
||||||
// no need to keep it around any longer
|
// in case of asynchronous execution we don't need this data any more
|
||||||
delete data;
|
// after the child terminates
|
||||||
|
delete data;
|
||||||
|
}
|
||||||
|
else // sync execution
|
||||||
|
{
|
||||||
|
// let wxExecute() know that the process has terminated
|
||||||
|
data->pid = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user