Commit d80dc792 authored by Markus Amsler's avatar Markus Amsler Committed by Alexandre Julliard

d3d9: Handle volume container in d3d9.

parent 467b1dd3
...@@ -239,6 +239,9 @@ typedef struct IDirect3DVolume9Impl ...@@ -239,6 +239,9 @@ typedef struct IDirect3DVolume9Impl
/* IDirect3DVolume9 fields */ /* IDirect3DVolume9 fields */
IWineD3DVolume *wineD3DVolume; IWineD3DVolume *wineD3DVolume;
/* The volume container */
IUnknown *container;
/* If set forward refcounting to this object */ /* If set forward refcounting to this object */
IUnknown *forwardReference; IUnknown *forwardReference;
} IDirect3DVolume9Impl; } IDirect3DVolume9Impl;
......
...@@ -111,35 +111,17 @@ static HRESULT WINAPI IDirect3DVolume9Impl_FreePrivateData(LPDIRECT3DVOLUME9 ifa ...@@ -111,35 +111,17 @@ static HRESULT WINAPI IDirect3DVolume9Impl_FreePrivateData(LPDIRECT3DVOLUME9 ifa
static HRESULT WINAPI IDirect3DVolume9Impl_GetContainer(LPDIRECT3DVOLUME9 iface, REFIID riid, void** ppContainer) { static HRESULT WINAPI IDirect3DVolume9Impl_GetContainer(LPDIRECT3DVOLUME9 iface, REFIID riid, void** ppContainer) {
IDirect3DVolume9Impl *This = (IDirect3DVolume9Impl *)iface; IDirect3DVolume9Impl *This = (IDirect3DVolume9Impl *)iface;
IWineD3DBase *wineD3DContainer = NULL;
IUnknown *wineD3DContainerParent = NULL;
HRESULT res; HRESULT res;
TRACE("(This %p, riid %s, ppContainer %p)\n", This, debugstr_guid(riid), ppContainer); TRACE("(This %p, riid %s, ppContainer %p)\n", This, debugstr_guid(riid), ppContainer);
if (!This->container) return E_NOINTERFACE;
if (!ppContainer) { if (!ppContainer) {
ERR("Called without a valid ppContainer.\n"); ERR("Called without a valid ppContainer.\n");
} }
/* Get the WineD3D container. */ res = IUnknown_QueryInterface(This->container, riid, ppContainer);
res = IWineD3DVolume_GetContainer(This->wineD3DVolume, &IID_IWineD3DBase, (void **)&wineD3DContainer);
if (res != D3D_OK) return res;
if (!wineD3DContainer) {
ERR("IWineD3DSurface_GetContainer should never return NULL\n");
}
/* Get the parent */
IWineD3DBase_GetParent(wineD3DContainer, &wineD3DContainerParent);
IUnknown_Release(wineD3DContainer);
if (!wineD3DContainerParent) {
ERR("IWineD3DBase_GetParent should never return NULL\n");
}
/* Now, query the interface of the parent for the riid */
res = IUnknown_QueryInterface(wineD3DContainerParent, riid, ppContainer);
IUnknown_Release(wineD3DContainerParent);
TRACE("Returning ppContainer %p, *ppContainer %p\n", ppContainer, *ppContainer); TRACE("Returning ppContainer %p, *ppContainer %p\n", ppContainer, *ppContainer);
...@@ -224,6 +206,7 @@ HRESULT WINAPI D3D9CB_CreateVolume(IUnknown *pDevice, IUnknown *pSuperior, UINT ...@@ -224,6 +206,7 @@ HRESULT WINAPI D3D9CB_CreateVolume(IUnknown *pDevice, IUnknown *pSuperior, UINT
*ppVolume = NULL; *ppVolume = NULL;
} else { } else {
*ppVolume = (IWineD3DVolume *)object->wineD3DVolume; *ppVolume = (IWineD3DVolume *)object->wineD3DVolume;
object->container = pSuperior;
object->forwardReference = pSuperior; object->forwardReference = pSuperior;
} }
TRACE("(%p) Created volume %p\n", This, *ppVolume); TRACE("(%p) Created volume %p\n", This, *ppVolume);
......
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