[PATCH v2 1/2] user32: Let nulldrv return some dummy monitor information.

Jacek Caban jacek at codeweavers.com
Sun Sep 30 07:04:02 CDT 2018


Hi Bernhard,


On 28/09/2018 23:08, Bernhard Übelacker wrote:
> Wine-Bug:https://bugs.winehq.org/show_bug.cgi?id=43187
>
> Signed-off-by: Bernhard Übelacker<bernhardu at mailbox.org>
> ---
> Supersedes patch 151898.
>
> v2: No changes to v1.
> ---
>   dlls/user32/driver.c | 19 +++++++++++++++++--
>   1 file changed, 17 insertions(+), 2 deletions(-)
>
> diff --git a/dlls/user32/driver.c b/dlls/user32/driver.c
> index 561a126bd6..03296d518c 100644
> --- a/dlls/user32/driver.c
> +++ b/dlls/user32/driver.c
> @@ -354,7 +354,12 @@ static LONG CDECL nulldrv_ChangeDisplaySettingsEx( LPCWSTR name, LPDEVMODEW mode
>   
>   static BOOL CDECL nulldrv_EnumDisplayMonitors( HDC hdc, LPRECT rect, MONITORENUMPROC proc, LPARAM lp )
>   {
> -    return FALSE;
> +    RECT r = {0, 0, 640, 480};
> +
> +    TRACE("(%p, %p, %p, 0x%lx)\n", hdc, rect, proc, lp);
> +
> +    proc(NULL, hdc, &r, lp);
> +    return TRUE;
>   }

NULL doesn't seem to be a good choice for monitor handle here. It's 
probably worth testing.

>   
>   static BOOL CDECL nulldrv_EnumDisplaySettingsEx( LPCWSTR name, DWORD num, LPDEVMODEW mode, DWORD flags )
> @@ -364,7 +369,17 @@ static BOOL CDECL nulldrv_EnumDisplaySettingsEx( LPCWSTR name, DWORD num, LPDEVM
>   
>   static BOOL CDECL nulldrv_GetMonitorInfo( HMONITOR handle, LPMONITORINFO info )
>   {
> -    return FALSE;
> +    RECT r = {0, 0, 640, 480};
> +    const WCHAR device[] = {'W','i','n','D','i','s','c',0};

It should be static const.

> +
> +    TRACE("(%p, %p)\n", handle, info);
> +
> +    info->rcMonitor = r;
> +    info->rcWork = r;
> +    info->dwFlags = MONITORINFOF_PRIMARY;
> +    if (info->cbSize >= sizeof(MONITORINFOEXW))
> +        lstrcpyW( ((MONITORINFOEXW *)info)->szDevice, device );
> +    return TRUE;
>   }

Monitor handle is not used, so maybe it's not too important, but we 
should probably validate it anyway.

Thanks,
Jacek
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.winehq.org/pipermail/wine-devel/attachments/20180930/f49e36ed/attachment.html>


More information about the wine-devel mailing list