Henri Verbeet : ddraw: We can't render to the desktop window either.
Alexandre Julliard
julliard at winehq.org
Fri Nov 18 10:19:05 CST 2011
Module: wine
Branch: master
Commit: 8e6f5c34a2c657fa714d3d59f7918953dc84d883
URL: http://source.winehq.org/git/wine.git/?a=commit;h=8e6f5c34a2c657fa714d3d59f7918953dc84d883
Author: Henri Verbeet <hverbeet at 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);
}
}
More information about the wine-cvs
mailing list