shell32: Dynamically allocate buffer for command.
This commit is contained in:
parent
75ba711932
commit
f2748c7af3
|
@ -1417,11 +1417,12 @@ BOOL SHELL_execute( LPSHELLEXECUTEINFOW sei, SHELL_ExecuteW32 execfunc )
|
||||||
SEE_MASK_CONNECTNETDRV | SEE_MASK_FLAG_DDEWAIT | SEE_MASK_FLAG_NO_UI |
|
SEE_MASK_CONNECTNETDRV | SEE_MASK_FLAG_DDEWAIT | SEE_MASK_FLAG_NO_UI |
|
||||||
SEE_MASK_UNICODE | SEE_MASK_ASYNCOK | SEE_MASK_HMONITOR;
|
SEE_MASK_UNICODE | SEE_MASK_ASYNCOK | SEE_MASK_HMONITOR;
|
||||||
|
|
||||||
WCHAR parametersBuffer[1024], dirBuffer[MAX_PATH];
|
WCHAR parametersBuffer[1024], dirBuffer[MAX_PATH], wcmdBuffer[1024];
|
||||||
WCHAR *wszApplicationName, *wszParameters, *wszDir;
|
WCHAR *wszApplicationName, *wszParameters, *wszDir, *wcmd;
|
||||||
DWORD dwApplicationNameLen = MAX_PATH+2;
|
DWORD dwApplicationNameLen = MAX_PATH+2;
|
||||||
DWORD parametersLen = sizeof(parametersBuffer) / sizeof(WCHAR);
|
DWORD parametersLen = sizeof(parametersBuffer) / sizeof(WCHAR);
|
||||||
DWORD dirLen = sizeof(dirBuffer) / sizeof(WCHAR);
|
DWORD dirLen = sizeof(dirBuffer) / sizeof(WCHAR);
|
||||||
|
DWORD wcmdLen = sizeof(wcmdBuffer) / sizeof(WCHAR);
|
||||||
DWORD len;
|
DWORD len;
|
||||||
SHELLEXECUTEINFOW sei_tmp; /* modifiable copy of SHELLEXECUTEINFO struct */
|
SHELLEXECUTEINFOW sei_tmp; /* modifiable copy of SHELLEXECUTEINFO struct */
|
||||||
WCHAR wfileName[MAX_PATH];
|
WCHAR wfileName[MAX_PATH];
|
||||||
|
@ -1429,7 +1430,6 @@ BOOL SHELL_execute( LPSHELLEXECUTEINFOW sei, SHELL_ExecuteW32 execfunc )
|
||||||
WCHAR lpstrProtocol[256];
|
WCHAR lpstrProtocol[256];
|
||||||
LPCWSTR lpFile;
|
LPCWSTR lpFile;
|
||||||
UINT_PTR retval = SE_ERR_NOASSOC;
|
UINT_PTR retval = SE_ERR_NOASSOC;
|
||||||
WCHAR wcmd[1024];
|
|
||||||
BOOL appKnownSingular = FALSE;
|
BOOL appKnownSingular = FALSE;
|
||||||
|
|
||||||
/* make a local copy of the LPSHELLEXECUTEINFO structure and work with this from now on */
|
/* make a local copy of the LPSHELLEXECUTEINFO structure and work with this from now on */
|
||||||
|
@ -1681,6 +1681,15 @@ BOOL SHELL_execute( LPSHELLEXECUTEINFOW sei, SHELL_ExecuteW32 execfunc )
|
||||||
|
|
||||||
lpFile = wfileName;
|
lpFile = wfileName;
|
||||||
|
|
||||||
|
wcmd = wcmdBuffer;
|
||||||
|
len = lstrlenW(wszApplicationName) + 1;
|
||||||
|
if (sei_tmp.lpParameters[0])
|
||||||
|
len += 1 + lstrlenW(wszParameters);
|
||||||
|
if (len > wcmdLen)
|
||||||
|
{
|
||||||
|
wcmd = HeapAlloc(GetProcessHeap(), 0, len * sizeof(WCHAR));
|
||||||
|
wcmdLen = len;
|
||||||
|
}
|
||||||
strcpyW(wcmd, wszApplicationName);
|
strcpyW(wcmd, wszApplicationName);
|
||||||
if (sei_tmp.lpParameters[0]) {
|
if (sei_tmp.lpParameters[0]) {
|
||||||
strcatW(wcmd, wSpace);
|
strcatW(wcmd, wSpace);
|
||||||
|
@ -1694,12 +1703,14 @@ BOOL SHELL_execute( LPSHELLEXECUTEINFOW sei, SHELL_ExecuteW32 execfunc )
|
||||||
HeapFree(GetProcessHeap(), 0, wszParameters);
|
HeapFree(GetProcessHeap(), 0, wszParameters);
|
||||||
if (wszDir != dirBuffer)
|
if (wszDir != dirBuffer)
|
||||||
HeapFree(GetProcessHeap(), 0, wszDir);
|
HeapFree(GetProcessHeap(), 0, wszDir);
|
||||||
|
if (wcmd != wcmdBuffer)
|
||||||
|
HeapFree(GetProcessHeap(), 0, wcmd);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Else, try to find the executable */
|
/* Else, try to find the executable */
|
||||||
wcmd[0] = '\0';
|
wcmd[0] = '\0';
|
||||||
retval = SHELL_FindExecutable(sei_tmp.lpDirectory, lpFile, sei_tmp.lpVerb, wcmd, 1024, lpstrProtocol, &env, sei_tmp.lpIDList, sei_tmp.lpParameters);
|
retval = SHELL_FindExecutable(sei_tmp.lpDirectory, lpFile, sei_tmp.lpVerb, wcmd, wcmdLen, lpstrProtocol, &env, sei_tmp.lpIDList, sei_tmp.lpParameters);
|
||||||
if (retval > 32) /* Found */
|
if (retval > 32) /* Found */
|
||||||
{
|
{
|
||||||
retval = SHELL_quote_and_execute( wcmd, wszParameters, lpstrProtocol,
|
retval = SHELL_quote_and_execute( wcmd, wszParameters, lpstrProtocol,
|
||||||
|
@ -1754,6 +1765,8 @@ BOOL SHELL_execute( LPSHELLEXECUTEINFOW sei, SHELL_ExecuteW32 execfunc )
|
||||||
HeapFree(GetProcessHeap(), 0, wszParameters);
|
HeapFree(GetProcessHeap(), 0, wszParameters);
|
||||||
if (wszDir != dirBuffer)
|
if (wszDir != dirBuffer)
|
||||||
HeapFree(GetProcessHeap(), 0, wszDir);
|
HeapFree(GetProcessHeap(), 0, wszDir);
|
||||||
|
if (wcmd != wcmdBuffer)
|
||||||
|
HeapFree(GetProcessHeap(), 0, wcmd);
|
||||||
|
|
||||||
sei->hInstApp = (HINSTANCE)(retval > 32 ? 33 : retval);
|
sei->hInstApp = (HINSTANCE)(retval > 32 ? 33 : retval);
|
||||||
return retval > 32;
|
return retval > 32;
|
||||||
|
|
Loading…
Reference in New Issue