winevdm: Use mangled short path names for DOSBox.

This commit is contained in:
André Hentschel 2011-08-30 21:20:24 +02:00 committed by Alexandre Julliard
parent 124cdf913a
commit f9c6b4ba40
1 changed files with 5 additions and 3 deletions

View File

@ -154,7 +154,7 @@ static void start_dosbox( const char *appname, const char *args )
const char *config_dir = wine_get_config_dir(); const char *config_dir = wine_get_config_dir();
WCHAR path[MAX_PATH], config[MAX_PATH]; WCHAR path[MAX_PATH], config[MAX_PATH];
HANDLE file; HANDLE file;
char *p, *buffer; char *p, *buffer, app[MAX_PATH];
int i; int i;
int ret = 1; int ret = 1;
DWORD written, drives = GetLogicalDrives(); DWORD written, drives = GetLogicalDrives();
@ -164,6 +164,8 @@ static void start_dosbox( const char *appname, const char *args )
if (!GetTempPathW( MAX_PATH, path )) return; if (!GetTempPathW( MAX_PATH, path )) return;
if (!GetTempFileNameW( path, cfgW, 0, config )) return; if (!GetTempFileNameW( path, cfgW, 0, config )) return;
if (!GetCurrentDirectoryW( MAX_PATH, path )) return; if (!GetCurrentDirectoryW( MAX_PATH, path )) return;
if (!GetShortPathNameA( appname, app, MAX_PATH )) return;
if (!GetShortPathNameW( path, path, MAX_PATH )) return;
file = CreateFileW( config, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, 0, 0 ); file = CreateFileW( config, GENERIC_WRITE, 0, NULL, CREATE_ALWAYS, 0, 0 );
if (file == INVALID_HANDLE_VALUE) return; if (file == INVALID_HANDLE_VALUE) return;
@ -171,7 +173,7 @@ static void start_dosbox( const char *appname, const char *args )
sizeof("mount -z c") + sizeof("config -securemode") + sizeof("mount -z c") + sizeof("config -securemode") +
25 * (strlen(config_dir) + sizeof("mount c /dosdevices/c:")) + 25 * (strlen(config_dir) + sizeof("mount c /dosdevices/c:")) +
4 * strlenW( path ) + 4 * strlenW( path ) +
6 + strlen( appname ) + strlen( args ) + 20 ); 6 + strlen( app ) + strlen( args ) + 20 );
p = buffer; p = buffer;
p += sprintf( p, "[autoexec]\n" ); p += sprintf( p, "[autoexec]\n" );
for (i = 25; i >= 0; i--) for (i = 25; i >= 0; i--)
@ -186,7 +188,7 @@ static void start_dosbox( const char *appname, const char *args )
p += sprintf( p, "%c:\ncd ", path[0] ); p += sprintf( p, "%c:\ncd ", path[0] );
p += WideCharToMultiByte( CP_UNIXCP, 0, path + 2, -1, p, 4 * strlenW(path), NULL, NULL ) - 1; p += WideCharToMultiByte( CP_UNIXCP, 0, path + 2, -1, p, 4 * strlenW(path), NULL, NULL ) - 1;
p += sprintf( p, "\nconfig -securemode\n" ); p += sprintf( p, "\nconfig -securemode\n" );
p += sprintf( p, "%s %s\n", appname, args ); p += sprintf( p, "%s %s\n", app, args );
p += sprintf( p, "exit\n" ); p += sprintf( p, "exit\n" );
if (WriteFile( file, buffer, strlen(buffer), &written, NULL ) && written == strlen(buffer)) if (WriteFile( file, buffer, strlen(buffer), &written, NULL ) && written == strlen(buffer))
{ {