Module: wine Branch: master Commit: 8e6f5c34a2c657fa714d3d59f7918953dc84d883 URL: http://source.winehq.org/git/wine.git/?a=commit;h=8e6f5c34a2c657fa714d3d59f7...
Author: Henri Verbeet hverbeet@codeweavers.com Date: Thu Nov 17 20:11:40 2011 +0100
ddraw: We can't render to the desktop window either.
---
dlls/ddraw/ddraw.c | 4 ++-- dlls/ddraw/ddraw_private.h | 7 +++++++ dlls/ddraw/surface.c | 4 ++-- 3 files changed, 11 insertions(+), 4 deletions(-)
diff --git a/dlls/ddraw/ddraw.c b/dlls/ddraw/ddraw.c index 9ca3473..8cb2596 100644 --- a/dlls/ddraw/ddraw.c +++ b/dlls/ddraw/ddraw.c @@ -452,7 +452,7 @@ void ddraw_destroy_swapchain(IDirectDrawImpl *ddraw) wined3d_device_uninit_gdi(ddraw->wined3d_device); }
- ddraw->swapchain_window = NULL; + ddraw_set_swapchain_window(ddraw, NULL);
TRACE("Swapchain destroyed.\n"); } @@ -2655,7 +2655,7 @@ static HRESULT ddraw_create_swapchain(IDirectDrawImpl *ddraw, IDirectDrawSurface }
if (SUCCEEDED(hr)) - ddraw->swapchain_window = ddraw->dest_window; + ddraw_set_swapchain_window(ddraw, ddraw->dest_window);
return hr; } diff --git a/dlls/ddraw/ddraw_private.h b/dlls/ddraw/ddraw_private.h index 0f2c6ab..f53c93f 100644 --- a/dlls/ddraw/ddraw_private.h +++ b/dlls/ddraw/ddraw_private.h @@ -128,6 +128,13 @@ struct IDirectDrawImpl HRESULT ddraw_init(IDirectDrawImpl *ddraw, WINED3DDEVTYPE device_type) DECLSPEC_HIDDEN; void ddraw_destroy_swapchain(IDirectDrawImpl *ddraw) DECLSPEC_HIDDEN;
+static inline void ddraw_set_swapchain_window(struct IDirectDrawImpl *ddraw, HWND window) +{ + if (window == GetDesktopWindow()) + window = NULL; + ddraw->swapchain_window = window; +} + /* Utility functions */ void DDRAW_Convert_DDSCAPS_1_To_2(const DDSCAPS *pIn, DDSCAPS2 *pOut) DECLSPEC_HIDDEN; void DDRAW_Convert_DDDEVICEIDENTIFIER_2_To_1(const DDDEVICEIDENTIFIER2 *pIn, DDDEVICEIDENTIFIER *pOut) DECLSPEC_HIDDEN; diff --git a/dlls/ddraw/surface.c b/dlls/ddraw/surface.c index 854ec3c..864b3ba 100644 --- a/dlls/ddraw/surface.c +++ b/dlls/ddraw/surface.c @@ -3952,12 +3952,12 @@ static HRESULT WINAPI ddraw_surface7_SetClipper(IDirectDrawSurface7 *iface, if (clipWindow) { wined3d_swapchain_set_window(This->ddraw->wined3d_swapchain, clipWindow); - This->ddraw->swapchain_window = clipWindow; + ddraw_set_swapchain_window(This->ddraw, clipWindow); } else { wined3d_swapchain_set_window(This->ddraw->wined3d_swapchain, This->ddraw->d3d_window); - This->ddraw->swapchain_window = This->ddraw->dest_window; + ddraw_set_swapchain_window(This->ddraw, This->ddraw->dest_window); } }