Commit a9c33bbc authored by Alexandre Julliard's avatar Alexandre Julliard

kernel32: Try to load a 32-bit builtin in WinExec16 if the file doesn't exist.

parent a77e369c
...@@ -119,6 +119,15 @@ static inline void patch_code_segment( NE_MODULE *pModule ) ...@@ -119,6 +119,15 @@ static inline void patch_code_segment( NE_MODULE *pModule )
/*********************************************************************** /***********************************************************************
* contains_path
*/
static inline int contains_path( LPCSTR name )
{
return ((*name && (name[1] == ':')) || strchr(name, '/') || strchr(name, '\\'));
}
/***********************************************************************
* NE_strcasecmp * NE_strcasecmp
* *
* locale-independent case conversion for module lookups * locale-independent case conversion for module lookups
...@@ -1674,6 +1683,8 @@ HINSTANCE16 WINAPI WinExec16( LPCSTR lpCmdLine, UINT16 nCmdShow ) ...@@ -1674,6 +1683,8 @@ HINSTANCE16 WINAPI WinExec16( LPCSTR lpCmdLine, UINT16 nCmdShow )
int arglen; int arglen;
HINSTANCE16 ret; HINSTANCE16 ret;
char buffer[MAX_PATH]; char buffer[MAX_PATH];
LOADPARAMS16 params;
WORD showCmd[2];
if (*lpCmdLine == '"') /* has to be only one and only at beginning ! */ if (*lpCmdLine == '"') /* has to be only one and only at beginning ! */
{ {
...@@ -1722,23 +1733,29 @@ HINSTANCE16 WINAPI WinExec16( LPCSTR lpCmdLine, UINT16 nCmdShow ) ...@@ -1722,23 +1733,29 @@ HINSTANCE16 WINAPI WinExec16( LPCSTR lpCmdLine, UINT16 nCmdShow )
TRACE("name: '%s', cmdline: '%.*s'\n", name, cmdline[0], &cmdline[1]); TRACE("name: '%s', cmdline: '%.*s'\n", name, cmdline[0], &cmdline[1]);
if (SearchPathA( NULL, name, ".exe", sizeof(buffer), buffer, NULL )) showCmd[0] = 2;
{ showCmd[1] = nCmdShow;
LOADPARAMS16 params;
WORD showCmd[2];
showCmd[0] = 2;
showCmd[1] = nCmdShow;
params.hEnvironment = 0; params.hEnvironment = 0;
params.cmdLine = MapLS( cmdline ); params.cmdLine = MapLS( cmdline );
params.showCmd = MapLS( showCmd ); params.showCmd = MapLS( showCmd );
params.reserved = 0; params.reserved = 0;
if (SearchPathA( NULL, name, ".exe", sizeof(buffer), buffer, NULL ))
{
ret = LoadModule16( buffer, &params ); ret = LoadModule16( buffer, &params );
UnMapLS( params.cmdLine );
UnMapLS( params.showCmd );
} }
else ret = GetLastError(); else if (!contains_path( name )) /* try 16-bit builtin */
{
lstrcpynA( buffer, name, sizeof(buffer) );
if (strlen( buffer ) < sizeof(buffer) - 4 && !strchr( buffer, '.' )) strcat( buffer, ".exe" );
ret = LoadModule16( buffer, &params );
if (ret == ERROR_FILE_NOT_FOUND) ret = 21; /* it might be a 32-bit builtin too */
}
else ret = ERROR_FILE_NOT_FOUND;
UnMapLS( params.cmdLine );
UnMapLS( params.showCmd );
HeapFree( GetProcessHeap(), 0, cmdline ); HeapFree( GetProcessHeap(), 0, cmdline );
if (name != lpCmdLine) HeapFree( GetProcessHeap(), 0, name ); if (name != lpCmdLine) HeapFree( GetProcessHeap(), 0, name );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment