fix for crash when using wxEXEC_NODISABLE
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32516 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -888,14 +888,12 @@ long wxExecute(const wxString& cmd, int flags, wxProcess *handler)
|
|||||||
return pi.dwProcessId;
|
return pi.dwProcessId;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxAppTraits *traits = NULL;
|
wxAppTraits *traits = wxTheApp ? wxTheApp->GetTraits() : NULL;
|
||||||
|
wxCHECK_MSG( traits, -1, _T("no wxAppTraits in wxExecute()?") );
|
||||||
|
|
||||||
void *cookie = NULL;
|
void *cookie = NULL;
|
||||||
if ( !(flags & wxEXEC_NODISABLE) )
|
if ( !(flags & wxEXEC_NODISABLE) )
|
||||||
{
|
{
|
||||||
if ( wxTheApp )
|
|
||||||
traits = wxTheApp->GetTraits();
|
|
||||||
wxCHECK_MSG( traits, -1, _T("no wxAppTraits in wxExecute()?") );
|
|
||||||
|
|
||||||
// disable all app windows while waiting for the child process to finish
|
// disable all app windows while waiting for the child process to finish
|
||||||
cookie = traits->BeforeChildWaitLoop();
|
cookie = traits->BeforeChildWaitLoop();
|
||||||
}
|
}
|
||||||
@@ -916,8 +914,11 @@ long wxExecute(const wxString& cmd, int flags, wxProcess *handler)
|
|||||||
traits->AlwaysYield();
|
traits->AlwaysYield();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( traits )
|
if ( !(flags & wxEXEC_NODISABLE) )
|
||||||
|
{
|
||||||
|
// reenable disabled windows back
|
||||||
traits->AfterChildWaitLoop(cookie);
|
traits->AfterChildWaitLoop(cookie);
|
||||||
|
}
|
||||||
|
|
||||||
DWORD dwExitCode = data->dwExitCode;
|
DWORD dwExitCode = data->dwExitCode;
|
||||||
delete data;
|
delete data;
|
||||||
|
Reference in New Issue
Block a user