Commit 88121935 authored by Henri Verbeet's avatar Henri Verbeet Committed by Alexandre Julliard

ddraw: Implement ddraw7_RestoreAllSurfaces().

parent 8d4988a4
...@@ -2675,27 +2675,20 @@ static HRESULT WINAPI ddraw4_GetSurfaceFromDC(IDirectDraw4 *iface, HDC dc, ...@@ -2675,27 +2675,20 @@ static HRESULT WINAPI ddraw4_GetSurfaceFromDC(IDirectDraw4 *iface, HDC dc,
return hr; return hr;
} }
/***************************************************************************** static HRESULT CALLBACK restore_callback(IDirectDrawSurface7 *surface, DDSURFACEDESC2 *desc, void *context)
* IDirectDraw7::RestoreAllSurfaces {
* IDirectDrawSurface_Restore(surface);
* Calls the restore method of all surfaces IDirectDrawSurface_Release(surface);
*
* Params: return DDENUMRET_OK;
* }
* Returns:
* Always returns DD_OK because it's a stub
*
*****************************************************************************/
static HRESULT WINAPI ddraw7_RestoreAllSurfaces(IDirectDraw7 *iface) static HRESULT WINAPI ddraw7_RestoreAllSurfaces(IDirectDraw7 *iface)
{ {
FIXME("iface %p stub!\n", iface); TRACE("iface %p.\n", iface);
/* This isn't hard to implement: Enumerate all WineD3D surfaces, return IDirectDraw7_EnumSurfaces(iface, DDENUMSURFACES_ALL | DDENUMSURFACES_DOESEXIST,
* get their parent and call their restore method. Do not implement NULL, NULL, restore_callback);
* it in WineD3D, as restoring a surface means re-creating the
* WineD3DDSurface
*/
return DD_OK;
} }
static HRESULT WINAPI ddraw4_RestoreAllSurfaces(IDirectDraw4 *iface) static HRESULT WINAPI ddraw4_RestoreAllSurfaces(IDirectDraw4 *iface)
......
...@@ -7718,7 +7718,7 @@ static void test_lost_device(void) ...@@ -7718,7 +7718,7 @@ static void test_lost_device(void)
hr = IDirectDraw4_TestCooperativeLevel(ddraw); hr = IDirectDraw4_TestCooperativeLevel(ddraw);
ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr); ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr);
hr = IDirectDrawSurface4_IsLost(surface); hr = IDirectDrawSurface4_IsLost(surface);
todo_wine ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr); ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr);
IDirectDrawSurface4_Release(surface); IDirectDrawSurface4_Release(surface);
refcount = IDirectDraw4_Release(ddraw); refcount = IDirectDraw4_Release(ddraw);
......
...@@ -7440,7 +7440,7 @@ static void test_lost_device(void) ...@@ -7440,7 +7440,7 @@ static void test_lost_device(void)
hr = IDirectDraw7_TestCooperativeLevel(ddraw); hr = IDirectDraw7_TestCooperativeLevel(ddraw);
ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr); ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr);
hr = IDirectDrawSurface7_IsLost(surface); hr = IDirectDrawSurface7_IsLost(surface);
todo_wine ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr); ok(hr == DD_OK, "Got unexpected hr %#x.\n", hr);
IDirectDrawSurface7_Release(surface); IDirectDrawSurface7_Release(surface);
refcount = IDirectDraw7_Release(ddraw); refcount = IDirectDraw7_Release(ddraw);
......
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