d3drm: Implement IDirect3DRMFrameX_AddChild.
This commit is contained in:
parent
d2fb2af8ee
commit
470468c72e
|
@ -18,6 +18,7 @@
|
||||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
#include "wine/debug.h"
|
#include "wine/debug.h"
|
||||||
|
|
||||||
#define COBJMACROS
|
#define COBJMACROS
|
||||||
|
@ -33,6 +34,9 @@ typedef struct {
|
||||||
IDirect3DRMFrame2 IDirect3DRMFrame2_iface;
|
IDirect3DRMFrame2 IDirect3DRMFrame2_iface;
|
||||||
IDirect3DRMFrame3 IDirect3DRMFrame3_iface;
|
IDirect3DRMFrame3 IDirect3DRMFrame3_iface;
|
||||||
LONG ref;
|
LONG ref;
|
||||||
|
ULONG nb_children;
|
||||||
|
ULONG children_capacity;
|
||||||
|
IDirect3DRMFrame3** children;
|
||||||
} IDirect3DRMFrameImpl;
|
} IDirect3DRMFrameImpl;
|
||||||
|
|
||||||
static inline IDirect3DRMFrameImpl *impl_from_IDirect3DRMFrame2(IDirect3DRMFrame2 *iface)
|
static inline IDirect3DRMFrameImpl *impl_from_IDirect3DRMFrame2(IDirect3DRMFrame2 *iface)
|
||||||
|
@ -45,6 +49,8 @@ static inline IDirect3DRMFrameImpl *impl_from_IDirect3DRMFrame3(IDirect3DRMFrame
|
||||||
return CONTAINING_RECORD(iface, IDirect3DRMFrameImpl, IDirect3DRMFrame3_iface);
|
return CONTAINING_RECORD(iface, IDirect3DRMFrameImpl, IDirect3DRMFrame3_iface);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline IDirect3DRMFrameImpl *unsafe_impl_from_IDirect3DRMFrame2(IDirect3DRMFrame2 *iface);
|
||||||
|
|
||||||
/*** IUnknown methods ***/
|
/*** IUnknown methods ***/
|
||||||
static HRESULT WINAPI IDirect3DRMFrame2Impl_QueryInterface(IDirect3DRMFrame2* iface,
|
static HRESULT WINAPI IDirect3DRMFrame2Impl_QueryInterface(IDirect3DRMFrame2* iface,
|
||||||
REFIID riid, void** object)
|
REFIID riid, void** object)
|
||||||
|
@ -89,11 +95,17 @@ static ULONG WINAPI IDirect3DRMFrame2Impl_Release(IDirect3DRMFrame2* iface)
|
||||||
{
|
{
|
||||||
IDirect3DRMFrameImpl *This = impl_from_IDirect3DRMFrame2(iface);
|
IDirect3DRMFrameImpl *This = impl_from_IDirect3DRMFrame2(iface);
|
||||||
ULONG ref = InterlockedDecrement(&This->ref);
|
ULONG ref = InterlockedDecrement(&This->ref);
|
||||||
|
ULONG i;
|
||||||
|
|
||||||
TRACE("(%p)->(): new ref = %d\n", This, ref);
|
TRACE("(%p)->(): new ref = %d\n", This, ref);
|
||||||
|
|
||||||
if (!ref)
|
if (!ref)
|
||||||
|
{
|
||||||
|
for (i = 0; i < This->nb_children; i++)
|
||||||
|
IDirect3DRMFrame3_Release(This->children[i]);
|
||||||
|
HeapFree(GetProcessHeap(), 0, This->children);
|
||||||
HeapFree(GetProcessHeap(), 0, This);
|
HeapFree(GetProcessHeap(), 0, This);
|
||||||
|
}
|
||||||
|
|
||||||
return ref;
|
return ref;
|
||||||
}
|
}
|
||||||
|
@ -185,10 +197,16 @@ static HRESULT WINAPI IDirect3DRMFrame2Impl_AddChild(IDirect3DRMFrame2* iface,
|
||||||
LPDIRECT3DRMFRAME child)
|
LPDIRECT3DRMFRAME child)
|
||||||
{
|
{
|
||||||
IDirect3DRMFrameImpl *This = impl_from_IDirect3DRMFrame2(iface);
|
IDirect3DRMFrameImpl *This = impl_from_IDirect3DRMFrame2(iface);
|
||||||
|
IDirect3DRMFrameImpl *frame;
|
||||||
|
|
||||||
FIXME("(%p/%p)->(%p): stub\n", iface, This, child);
|
TRACE("(%p/%p)->(%p)\n", iface, This, child);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
frame = unsafe_impl_from_IDirect3DRMFrame2((LPDIRECT3DRMFRAME2)child);
|
||||||
|
|
||||||
|
if (!frame)
|
||||||
|
return D3DRMERR_BADOBJECT;
|
||||||
|
|
||||||
|
return IDirect3DRMFrame3_AddChild(&This->IDirect3DRMFrame3_iface, &frame->IDirect3DRMFrame3_iface);
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI IDirect3DRMFrame2Impl_AddLight(IDirect3DRMFrame2* iface,
|
static HRESULT WINAPI IDirect3DRMFrame2Impl_AddLight(IDirect3DRMFrame2* iface,
|
||||||
|
@ -928,7 +946,6 @@ static const struct IDirect3DRMFrame2Vtbl Direct3DRMFrame2_Vtbl =
|
||||||
IDirect3DRMFrame2Impl_GetHierarchyBox
|
IDirect3DRMFrame2Impl_GetHierarchyBox
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*** IUnknown methods ***/
|
/*** IUnknown methods ***/
|
||||||
static HRESULT WINAPI IDirect3DRMFrame3Impl_QueryInterface(IDirect3DRMFrame3* iface,
|
static HRESULT WINAPI IDirect3DRMFrame3Impl_QueryInterface(IDirect3DRMFrame3* iface,
|
||||||
REFIID riid, void** object)
|
REFIID riid, void** object)
|
||||||
|
@ -1036,10 +1053,45 @@ static HRESULT WINAPI IDirect3DRMFrame3Impl_AddChild(IDirect3DRMFrame3* iface,
|
||||||
LPDIRECT3DRMFRAME3 child)
|
LPDIRECT3DRMFRAME3 child)
|
||||||
{
|
{
|
||||||
IDirect3DRMFrameImpl *This = impl_from_IDirect3DRMFrame3(iface);
|
IDirect3DRMFrameImpl *This = impl_from_IDirect3DRMFrame3(iface);
|
||||||
|
ULONG i;
|
||||||
|
IDirect3DRMFrame3** children;
|
||||||
|
|
||||||
FIXME("(%p/%p)->(%p): stub\n", iface, This, child);
|
TRACE("(%p/%p)->(%p)\n", iface, This, child);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
if (!child)
|
||||||
|
return D3DRMERR_BADOBJECT;
|
||||||
|
|
||||||
|
/* Check if already existing and return gracefully without increasing ref count */
|
||||||
|
for (i = 0; i < This->nb_children; i++)
|
||||||
|
if (This->children[i] == child)
|
||||||
|
return D3DRM_OK;
|
||||||
|
|
||||||
|
if ((This->nb_children + 1) > This->children_capacity)
|
||||||
|
{
|
||||||
|
ULONG new_capacity;
|
||||||
|
|
||||||
|
if (!This->children_capacity)
|
||||||
|
{
|
||||||
|
new_capacity = 16;
|
||||||
|
children = HeapAlloc(GetProcessHeap(), 0, new_capacity * sizeof(IDirect3DRMFrame3*));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
new_capacity = This->children_capacity * 2;
|
||||||
|
children = HeapReAlloc(GetProcessHeap(), 0, This->children, new_capacity * sizeof(IDirect3DRMFrame3*));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!children)
|
||||||
|
return E_OUTOFMEMORY;
|
||||||
|
|
||||||
|
This->children_capacity = new_capacity;
|
||||||
|
This->children = children;
|
||||||
|
}
|
||||||
|
|
||||||
|
This->children[This->nb_children++] = child;
|
||||||
|
IDirect3DRMFrame3_AddRef(child);
|
||||||
|
|
||||||
|
return D3DRM_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI IDirect3DRMFrame3Impl_AddLight(IDirect3DRMFrame3* iface,
|
static HRESULT WINAPI IDirect3DRMFrame3Impl_AddLight(IDirect3DRMFrame3* iface,
|
||||||
|
@ -1927,6 +1979,15 @@ static const struct IDirect3DRMFrame3Vtbl Direct3DRMFrame3_Vtbl =
|
||||||
IDirect3DRMFrame3Impl_GetMaterialOverride
|
IDirect3DRMFrame3Impl_GetMaterialOverride
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static inline IDirect3DRMFrameImpl *unsafe_impl_from_IDirect3DRMFrame2(IDirect3DRMFrame2 *iface)
|
||||||
|
{
|
||||||
|
if (!iface)
|
||||||
|
return NULL;
|
||||||
|
assert(iface->lpVtbl == &Direct3DRMFrame2_Vtbl);
|
||||||
|
|
||||||
|
return impl_from_IDirect3DRMFrame2(iface);
|
||||||
|
}
|
||||||
|
|
||||||
HRESULT Direct3DRMFrame_create(REFIID riid, IUnknown** ppObj)
|
HRESULT Direct3DRMFrame_create(REFIID riid, IUnknown** ppObj)
|
||||||
{
|
{
|
||||||
IDirect3DRMFrameImpl* object;
|
IDirect3DRMFrameImpl* object;
|
||||||
|
|
|
@ -446,7 +446,7 @@ static void test_Frame(void)
|
||||||
|
|
||||||
/* [Add/Delete]Child with NULL pointer */
|
/* [Add/Delete]Child with NULL pointer */
|
||||||
hr = IDirect3DRMFrame_AddChild(pFrameP1, NULL);
|
hr = IDirect3DRMFrame_AddChild(pFrameP1, NULL);
|
||||||
todo_wine ok(hr == D3DRMERR_BADOBJECT, "Should have returned D3DRMERR_BADOBJECT (hr = %x)\n", hr);
|
ok(hr == D3DRMERR_BADOBJECT, "Should have returned D3DRMERR_BADOBJECT (hr = %x)\n", hr);
|
||||||
CHECK_REFCOUNT(pFrameP1, 1);
|
CHECK_REFCOUNT(pFrameP1, 1);
|
||||||
|
|
||||||
hr = IDirect3DRMFrame_DeleteChild(pFrameP1, NULL);
|
hr = IDirect3DRMFrame_DeleteChild(pFrameP1, NULL);
|
||||||
|
@ -460,9 +460,9 @@ static void test_Frame(void)
|
||||||
todo_wine ok(pFrameTmp == NULL, "pFrameTmp = %p\n", pFrameTmp);
|
todo_wine ok(pFrameTmp == NULL, "pFrameTmp = %p\n", pFrameTmp);
|
||||||
|
|
||||||
hr = IDirect3DRMFrame_AddChild(pFrameP1, pFrameC);
|
hr = IDirect3DRMFrame_AddChild(pFrameP1, pFrameC);
|
||||||
todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
||||||
CHECK_REFCOUNT(pFrameP1, 1);
|
CHECK_REFCOUNT(pFrameP1, 1);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
CHECK_REFCOUNT(pFrameC, 2);
|
||||||
|
|
||||||
pArray = NULL;
|
pArray = NULL;
|
||||||
hr = IDirect3DRMFrame_GetChildren(pFrameP1, &pArray);
|
hr = IDirect3DRMFrame_GetChildren(pFrameP1, &pArray);
|
||||||
|
@ -489,7 +489,7 @@ static void test_Frame(void)
|
||||||
ok(hr == D3DRM_OK, "Cannot get IDirect3DRMFrame interface (hr = %x)\n", hr);
|
ok(hr == D3DRM_OK, "Cannot get IDirect3DRMFrame interface (hr = %x)\n", hr);
|
||||||
|
|
||||||
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC);
|
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC);
|
||||||
todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
||||||
|
|
||||||
pArray = NULL;
|
pArray = NULL;
|
||||||
|
@ -528,7 +528,7 @@ static void test_Frame(void)
|
||||||
|
|
||||||
/* Add child again */
|
/* Add child again */
|
||||||
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC);
|
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC);
|
||||||
todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
||||||
|
|
||||||
pArray = NULL;
|
pArray = NULL;
|
||||||
|
@ -548,7 +548,7 @@ static void test_Frame(void)
|
||||||
/* Delete child */
|
/* Delete child */
|
||||||
hr = IDirect3DRMFrame_DeleteChild(pFrameP2, pFrameC);
|
hr = IDirect3DRMFrame_DeleteChild(pFrameP2, pFrameC);
|
||||||
todo_wine ok(hr == D3DRM_OK, "Cannot delete child frame (hr = %x)\n", hr);
|
todo_wine ok(hr == D3DRM_OK, "Cannot delete child frame (hr = %x)\n", hr);
|
||||||
CHECK_REFCOUNT(pFrameC, 1);
|
todo_wine CHECK_REFCOUNT(pFrameC, 1);
|
||||||
|
|
||||||
pArray = NULL;
|
pArray = NULL;
|
||||||
hr = IDirect3DRMFrame_GetChildren(pFrameP2, &pArray);
|
hr = IDirect3DRMFrame_GetChildren(pFrameP2, &pArray);
|
||||||
|
@ -570,11 +570,11 @@ static void test_Frame(void)
|
||||||
|
|
||||||
/* Add two children */
|
/* Add two children */
|
||||||
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC);
|
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameC);
|
||||||
todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
||||||
|
|
||||||
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameP1);
|
hr = IDirect3DRMFrame_AddChild(pFrameP2, pFrameP1);
|
||||||
todo_wine ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
ok(hr == D3DRM_OK, "Cannot add child frame (hr = %x)\n", hr);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameP1, 3);
|
todo_wine CHECK_REFCOUNT(pFrameP1, 3);
|
||||||
|
|
||||||
pArray = NULL;
|
pArray = NULL;
|
||||||
|
@ -596,7 +596,7 @@ static void test_Frame(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
IDirect3DRMMeshBuilder_Release(pFrameP2);
|
IDirect3DRMMeshBuilder_Release(pFrameP2);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameC, 2);
|
CHECK_REFCOUNT(pFrameC, 2);
|
||||||
todo_wine CHECK_REFCOUNT(pFrameP1, 3);
|
todo_wine CHECK_REFCOUNT(pFrameP1, 3);
|
||||||
|
|
||||||
IDirect3DRMMeshBuilder_Release(pFrameC);
|
IDirect3DRMMeshBuilder_Release(pFrameC);
|
||||||
|
|
Loading…
Reference in New Issue