Commit b2361425 authored by Alexandre Julliard's avatar Alexandre Julliard

explorer: Allow to specify the name of the graphics driver in the /desktop option.

parent 4473ce4d
...@@ -638,7 +638,7 @@ static BOOL get_default_desktop_size( const WCHAR *name, unsigned int *width, un ...@@ -638,7 +638,7 @@ static BOOL get_default_desktop_size( const WCHAR *name, unsigned int *width, un
return found; return found;
} }
static HMODULE load_graphics_driver( const GUID *guid ) static HMODULE load_graphics_driver( const WCHAR *driver, const GUID *guid )
{ {
static const WCHAR device_keyW[] = { static const WCHAR device_keyW[] = {
'S','y','s','t','e','m','\\', 'S','y','s','t','e','m','\\',
...@@ -660,15 +660,19 @@ static HMODULE load_graphics_driver( const GUID *guid ) ...@@ -660,15 +660,19 @@ static HMODULE load_graphics_driver( const GUID *guid )
HKEY hkey; HKEY hkey;
char error[80]; char error[80];
strcpyW( buffer, default_driver ); if (!driver)
/* @@ Wine registry key: HKCU\Software\Wine\Drivers */
if (!RegOpenKeyW( HKEY_CURRENT_USER, driversW, &hkey ))
{ {
DWORD count = sizeof(buffer); strcpyW( buffer, default_driver );
RegQueryValueExW( hkey, graphicsW, 0, NULL, (LPBYTE)buffer, &count );
RegCloseKey( hkey ); /* @@ Wine registry key: HKCU\Software\Wine\Drivers */
if (!RegOpenKeyW( HKEY_CURRENT_USER, driversW, &hkey ))
{
DWORD count = sizeof(buffer);
RegQueryValueExW( hkey, graphicsW, 0, NULL, (LPBYTE)buffer, &count );
RegCloseKey( hkey );
}
} }
else lstrcpynW( buffer, driver, sizeof(buffer)/sizeof(WCHAR) );
name = buffer; name = buffer;
while (name) while (name)
...@@ -773,7 +777,7 @@ void manage_desktop( WCHAR *arg ) ...@@ -773,7 +777,7 @@ void manage_desktop( WCHAR *arg )
HWND hwnd, msg_hwnd; HWND hwnd, msg_hwnd;
HMODULE graphics_driver; HMODULE graphics_driver;
unsigned int width, height; unsigned int width, height;
WCHAR *cmdline = NULL; WCHAR *cmdline = NULL, *driver = NULL;
WCHAR *p = arg; WCHAR *p = arg;
const WCHAR *name = NULL; const WCHAR *name = NULL;
...@@ -787,12 +791,16 @@ void manage_desktop( WCHAR *arg ) ...@@ -787,12 +791,16 @@ void manage_desktop( WCHAR *arg )
} }
/* parse the desktop option */ /* parse the desktop option */
/* the option is of the form /desktop=name[,widthxheight] */ /* the option is of the form /desktop=name[,widthxheight[,driver]] */
if (*arg == '=' || *arg == ',') if (*arg == '=' || *arg == ',')
{ {
arg++; arg++;
name = arg; name = arg;
if ((p = strchrW( arg, ',' ))) *p++ = 0; if ((p = strchrW( arg, ',' )))
{
*p++ = 0;
if ((driver = strchrW( p, ',' ))) *driver++ = 0;
}
if (!p || !parse_size( p, &width, &height )) if (!p || !parse_size( p, &width, &height ))
get_default_desktop_size( name, &width, &height ); get_default_desktop_size( name, &width, &height );
} }
...@@ -813,7 +821,7 @@ void manage_desktop( WCHAR *arg ) ...@@ -813,7 +821,7 @@ void manage_desktop( WCHAR *arg )
UuidCreate( &guid ); UuidCreate( &guid );
TRACE( "display guid %s\n", debugstr_guid(&guid) ); TRACE( "display guid %s\n", debugstr_guid(&guid) );
graphics_driver = load_graphics_driver( &guid ); graphics_driver = load_graphics_driver( driver, &guid );
/* create the desktop window */ /* create the desktop window */
hwnd = CreateWindowExW( 0, DESKTOP_CLASS_ATOM, NULL, hwnd = CreateWindowExW( 0, DESKTOP_CLASS_ATOM, NULL,
......
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