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:
Vadim Zeitlin
2008-03-22 15:37:16 +00:00
parent 69328170cc
commit e528a71bf1
3 changed files with 33 additions and 19 deletions

View File

@@ -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

View File

@@ -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

View File

@@ -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;
}
} }