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