d3drm: Implement IDirect3DRMTexture{2-3}_InitFromImage.
Signed-off-by: Aaryaman Vasishta <jem456.vasishta@gmail.com> Signed-off-by: Henri Verbeet <hverbeet@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
07c038c2b4
commit
9511d09852
|
@ -41,6 +41,7 @@ struct d3drm_texture
|
||||||
IDirect3DRMTexture2 IDirect3DRMTexture2_iface;
|
IDirect3DRMTexture2 IDirect3DRMTexture2_iface;
|
||||||
IDirect3DRMTexture3 IDirect3DRMTexture3_iface;
|
IDirect3DRMTexture3 IDirect3DRMTexture3_iface;
|
||||||
IDirect3DRM *d3drm;
|
IDirect3DRM *d3drm;
|
||||||
|
D3DRMIMAGE *image;
|
||||||
};
|
};
|
||||||
|
|
||||||
void d3drm_object_init(struct d3drm_object *object) DECLSPEC_HIDDEN;
|
void d3drm_object_init(struct d3drm_object *object) DECLSPEC_HIDDEN;
|
||||||
|
|
|
@ -1700,11 +1700,21 @@ static void test_Texture(void)
|
||||||
IDirect3DRMTexture *texture1;
|
IDirect3DRMTexture *texture1;
|
||||||
IDirect3DRMTexture2 *texture2;
|
IDirect3DRMTexture2 *texture2;
|
||||||
IDirect3DRMTexture3 *texture3;
|
IDirect3DRMTexture3 *texture3;
|
||||||
D3DRMIMAGE initimg = {
|
|
||||||
|
D3DRMIMAGE initimg =
|
||||||
|
{
|
||||||
2, 2, 1, 1, 32,
|
2, 2, 1, 1, 32,
|
||||||
TRUE, 2 * sizeof(DWORD), NULL, NULL,
|
TRUE, 2 * sizeof(DWORD), NULL, NULL,
|
||||||
0x000000ff, 0x0000ff00, 0x00ff0000, 0xff000000, 0, NULL
|
0x000000ff, 0x0000ff00, 0x00ff0000, 0xff000000, 0, NULL
|
||||||
}, *d3drm_img = NULL;
|
},
|
||||||
|
testimg =
|
||||||
|
{
|
||||||
|
0, 0, 0, 0, 0,
|
||||||
|
TRUE, 0, (void *)0xcafebabe, NULL,
|
||||||
|
0x000000ff, 0x0000ff00, 0x00ff0000, 0, 0, NULL
|
||||||
|
},
|
||||||
|
*d3drm_img = NULL;
|
||||||
|
|
||||||
DWORD pixel[4] = { 20000, 30000, 10000, 0 };
|
DWORD pixel[4] = { 20000, 30000, 10000, 0 };
|
||||||
DWORD size;
|
DWORD size;
|
||||||
CHAR cname[64] = {0};
|
CHAR cname[64] = {0};
|
||||||
|
@ -1853,22 +1863,103 @@ static void test_Texture(void)
|
||||||
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u, ref4 = %u.\n", ref1, ref4);
|
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u, ref4 = %u.\n", ref1, ref4);
|
||||||
|
|
||||||
/* InitFromImage tests */
|
/* InitFromImage tests */
|
||||||
d3drm_img = NULL;
|
/* Tests for validation of D3DRMIMAGE struct */
|
||||||
hr = IDirect3DRM2_CreateObject(d3drm2, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture2, (void **)&texture2);
|
testimg.rgb = 1;
|
||||||
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture2 interface (hr = %x).\n", hr);
|
testimg.palette = NULL;
|
||||||
|
testimg.palette_size = 0;
|
||||||
|
hr = IDirect3DRM2_CreateObject(d3drm2, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture2,
|
||||||
|
(void **)&texture2);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture2 interface (hr = %#x).\n", hr);
|
||||||
|
hr = IDirect3DRM3_CreateObject(d3drm3, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture3,
|
||||||
|
(void **)&texture3);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture3 interface (hr = %#x).\n", hr);
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &testimg);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture2 interface (hr = %#x)\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &testimg);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture3 interface (hr = %#x)\n", hr);
|
||||||
|
IDirect3DRMTexture2_Release(texture2);
|
||||||
|
IDirect3DRMTexture3_Release(texture3);
|
||||||
|
|
||||||
|
testimg.rgb = 0;
|
||||||
|
testimg.palette = (void *)0xdeadbeef;
|
||||||
|
testimg.palette_size = 0x39;
|
||||||
|
hr = IDirect3DRM2_CreateObject(d3drm2, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture2,
|
||||||
|
(void **)&texture2);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture2 interface (hr = %#x).\n", hr);
|
||||||
|
hr = IDirect3DRM3_CreateObject(d3drm3, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture3,
|
||||||
|
(void **)&texture3);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture3 interface (hr = %#x).\n", hr);
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &testimg);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture2 interface (hr = %#x)\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &testimg);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture3 interface (hr = %#x)\n", hr);
|
||||||
|
IDirect3DRMTexture2_Release(texture2);
|
||||||
|
IDirect3DRMTexture3_Release(texture3);
|
||||||
|
|
||||||
|
hr = IDirect3DRM2_CreateObject(d3drm2, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture2,
|
||||||
|
(void **)&texture2);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture2 interface (hr = %#x).\n", hr);
|
||||||
ref2 = get_refcount((IUnknown *)texture2);
|
ref2 = get_refcount((IUnknown *)texture2);
|
||||||
hr = IDirect3DRMTexture2_InitFromImage(texture2, NULL);
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, NULL);
|
||||||
todo_wine ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %x.\n", hr);
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
ref3 = get_refcount((IUnknown *)texture2);
|
ref3 = get_refcount((IUnknown *)texture2);
|
||||||
ok(ref3 == ref2, "expected ref3 == ref2, got ref2 = %u , ref3 = %u.\n", ref2, ref3);
|
ok(ref3 == ref2, "expected ref3 == ref2, got ref2 = %u , ref3 = %u.\n", ref2, ref3);
|
||||||
|
|
||||||
|
hr = IDirect3DRM3_CreateObject(d3drm3, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture3,
|
||||||
|
(void **)&texture3);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture3 interface (hr = %#x).\n", hr);
|
||||||
|
ref2 = get_refcount((IUnknown *)texture3);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, NULL);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
ref3 = get_refcount((IUnknown *)texture3);
|
||||||
|
ok(ref3 == ref2, "expected ref3 == ref2, got ref2 = %u , ref3 = %u.\n", ref2, ref3);
|
||||||
|
|
||||||
|
initimg.rgb = 0;
|
||||||
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
todo_wine ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture2 from image (hr = %x).\n", hr);
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
initimg.rgb = 1;
|
||||||
|
initimg.red_mask = 0;
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
initimg.red_mask = 0x000000ff;
|
||||||
|
initimg.green_mask = 0;
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
initimg.green_mask = 0x0000ff00;
|
||||||
|
initimg.blue_mask = 0;
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
initimg.blue_mask = 0x00ff0000;
|
||||||
|
initimg.buffer1 = NULL;
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
initimg.buffer1 = &pixel;
|
||||||
|
|
||||||
|
d3drm_img = NULL;
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
|
ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture2 from image (hr = %#x).\n", hr);
|
||||||
ref2 = get_refcount((IUnknown *)d3drm1);
|
ref2 = get_refcount((IUnknown *)d3drm1);
|
||||||
todo_wine ok(ref2 > ref1, "expected ref2 > ref1, got ref1 = %u , ref2 = %u.\n", ref1, ref2);
|
ok(ref2 > ref1, "expected ref2 > ref1, got ref1 = %u , ref2 = %u.\n", ref1, ref2);
|
||||||
ref3 = get_refcount((IUnknown *)d3drm2);
|
ref3 = get_refcount((IUnknown *)d3drm2);
|
||||||
ok(ref3 == ref1, "expected ref3 == ref1, got ref1 = %u , ref3 = %u.\n", ref1, ref3);
|
ok(ref3 == ref1, "expected ref3 == ref1, got ref1 = %u , ref3 = %u.\n", ref1, ref3);
|
||||||
ref4 = get_refcount((IUnknown *)d3drm3);
|
ref4 = get_refcount((IUnknown *)d3drm3);
|
||||||
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u , ref4 = %u.\n", ref1, ref4);
|
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u , ref4 = %u.\n", ref1, ref4);
|
||||||
|
|
||||||
|
hr = IDirect3DRMTexture2_InitFromImage(texture2, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
/* Release leaked reference to d3drm1 */
|
||||||
|
IDirect3DRM_Release(d3drm1);
|
||||||
|
|
||||||
d3drm_img = IDirect3DRMTexture2_GetImage(texture2);
|
d3drm_img = IDirect3DRMTexture2_GetImage(texture2);
|
||||||
todo_wine ok(!!d3drm_img, "Failed to get image.\n");
|
todo_wine ok(!!d3drm_img, "Failed to get image.\n");
|
||||||
todo_wine ok(d3drm_img == &initimg, "Expected image returned == %p, got %p.\n", &initimg, d3drm_img);
|
todo_wine ok(d3drm_img == &initimg, "Expected image returned == %p, got %p.\n", &initimg, d3drm_img);
|
||||||
|
@ -1881,21 +1972,19 @@ static void test_Texture(void)
|
||||||
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u, ref4 = %u.\n", ref1, ref4);
|
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u, ref4 = %u.\n", ref1, ref4);
|
||||||
|
|
||||||
d3drm_img = NULL;
|
d3drm_img = NULL;
|
||||||
hr = IDirect3DRM3_CreateObject(d3drm3, &CLSID_CDirect3DRMTexture, NULL, &IID_IDirect3DRMTexture3, (void **)&texture3);
|
|
||||||
ok(SUCCEEDED(hr), "Cannot get IDirect3DRMTexture3 interface (hr = %x).\n", hr);
|
|
||||||
ref2 = get_refcount((IUnknown *)texture3);
|
|
||||||
hr = IDirect3DRMTexture3_InitFromImage(texture3, NULL);
|
|
||||||
todo_wine ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %x.\n", hr);
|
|
||||||
ref3 = get_refcount((IUnknown *)texture3);
|
|
||||||
ok(ref3 == ref2, "expected ref3 == ref2, got ref2 = %u , ref3 = %u.\n", ref2, ref3);
|
|
||||||
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
todo_wine ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture3 from image (hr = %x).\n", hr);
|
ok(SUCCEEDED(hr), "Cannot initialize IDirect3DRMTexture3 from image (hr = %#x).\n", hr);
|
||||||
ref2 = get_refcount((IUnknown *)d3drm1);
|
ref2 = get_refcount((IUnknown *)d3drm1);
|
||||||
todo_wine ok(ref2 > ref1, "expected ref2 > ref1, got ref1 = %u , ref2 = %u.\n", ref1, ref2);
|
ok(ref2 > ref1, "expected ref2 > ref1, got ref1 = %u , ref2 = %u.\n", ref1, ref2);
|
||||||
ref3 = get_refcount((IUnknown *)d3drm2);
|
ref3 = get_refcount((IUnknown *)d3drm2);
|
||||||
ok(ref3 == ref1, "expected ref3 == ref1, got ref1 = %u , ref3 = %u.\n", ref1, ref3);
|
ok(ref3 == ref1, "expected ref3 == ref1, got ref1 = %u , ref3 = %u.\n", ref1, ref3);
|
||||||
ref4 = get_refcount((IUnknown *)d3drm3);
|
ref4 = get_refcount((IUnknown *)d3drm3);
|
||||||
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u , ref4 = %u.\n", ref1, ref4);
|
ok(ref4 == ref1, "expected ref4 == ref1, got ref1 = %u , ref4 = %u.\n", ref1, ref4);
|
||||||
|
|
||||||
|
hr = IDirect3DRMTexture3_InitFromImage(texture3, &initimg);
|
||||||
|
ok(hr == D3DRMERR_BADOBJECT, "Expected hr == D3DRMERR_BADOBJECT, got %#x.\n", hr);
|
||||||
|
IDirect3DRM_Release(d3drm1);
|
||||||
|
|
||||||
d3drm_img = IDirect3DRMTexture3_GetImage(texture3);
|
d3drm_img = IDirect3DRMTexture3_GetImage(texture3);
|
||||||
todo_wine ok(!!d3drm_img, "Failed to get image.\n");
|
todo_wine ok(!!d3drm_img, "Failed to get image.\n");
|
||||||
todo_wine ok(d3drm_img == &initimg, "Expected image returned == %p, got %p.\n", &initimg, d3drm_img);
|
todo_wine ok(d3drm_img == &initimg, "Expected image returned == %p, got %p.\n", &initimg, d3drm_img);
|
||||||
|
|
|
@ -49,9 +49,26 @@ static void d3drm_texture_destroy(struct d3drm_texture *texture)
|
||||||
TRACE("texture %p is being destroyed.\n", texture);
|
TRACE("texture %p is being destroyed.\n", texture);
|
||||||
|
|
||||||
d3drm_object_cleanup((IDirect3DRMObject*)&texture->IDirect3DRMTexture3_iface, &texture->obj);
|
d3drm_object_cleanup((IDirect3DRMObject*)&texture->IDirect3DRMTexture3_iface, &texture->obj);
|
||||||
|
if (texture->image)
|
||||||
|
IDirect3DRM_Release(texture->d3drm);
|
||||||
HeapFree(GetProcessHeap(), 0, texture);
|
HeapFree(GetProcessHeap(), 0, texture);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static BOOL d3drm_validate_image(D3DRMIMAGE *image)
|
||||||
|
{
|
||||||
|
if (!image
|
||||||
|
|| !image->red_mask
|
||||||
|
|| !image->green_mask
|
||||||
|
|| !image->blue_mask
|
||||||
|
|| !image->buffer1
|
||||||
|
|| !(image->rgb || (image->palette && image->palette_size)))
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI d3drm_texture1_QueryInterface(IDirect3DRMTexture *iface, REFIID riid, void **out)
|
static HRESULT WINAPI d3drm_texture1_QueryInterface(IDirect3DRMTexture *iface, REFIID riid, void **out)
|
||||||
{
|
{
|
||||||
struct d3drm_texture *texture = impl_from_IDirect3DRMTexture(iface);
|
struct d3drm_texture *texture = impl_from_IDirect3DRMTexture(iface);
|
||||||
|
@ -620,9 +637,11 @@ static D3DCOLOR WINAPI d3drm_texture2_GetDecalTransparentColor(IDirect3DRMTextur
|
||||||
|
|
||||||
static HRESULT WINAPI d3drm_texture2_InitFromImage(IDirect3DRMTexture2 *iface, D3DRMIMAGE *image)
|
static HRESULT WINAPI d3drm_texture2_InitFromImage(IDirect3DRMTexture2 *iface, D3DRMIMAGE *image)
|
||||||
{
|
{
|
||||||
FIXME("iface %p, image %p stub!\n", iface, image);
|
struct d3drm_texture *texture = impl_from_IDirect3DRMTexture2(iface);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
TRACE("iface %p, image %p.\n", iface, image);
|
||||||
|
|
||||||
|
return IDirect3DRMTexture3_InitFromImage(&texture->IDirect3DRMTexture3_iface, image);
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI d3drm_texture2_InitFromResource2(IDirect3DRMTexture2 *iface,
|
static HRESULT WINAPI d3drm_texture2_InitFromResource2(IDirect3DRMTexture2 *iface,
|
||||||
|
@ -947,9 +966,22 @@ static D3DCOLOR WINAPI d3drm_texture3_GetDecalTransparentColor(IDirect3DRMTextur
|
||||||
|
|
||||||
static HRESULT WINAPI d3drm_texture3_InitFromImage(IDirect3DRMTexture3 *iface, D3DRMIMAGE *image)
|
static HRESULT WINAPI d3drm_texture3_InitFromImage(IDirect3DRMTexture3 *iface, D3DRMIMAGE *image)
|
||||||
{
|
{
|
||||||
FIXME("iface %p, image %p stub!\n", iface, image);
|
struct d3drm_texture *texture = impl_from_IDirect3DRMTexture3(iface);
|
||||||
|
|
||||||
return E_NOTIMPL;
|
TRACE("iface %p, image %p.\n", iface, image);
|
||||||
|
|
||||||
|
if (!d3drm_validate_image(image))
|
||||||
|
return D3DRMERR_BADOBJECT;
|
||||||
|
|
||||||
|
/* d3drm intentionally leaks a reference to IDirect3DRM here if texture has already been initialized. */
|
||||||
|
IDirect3DRM_AddRef(texture->d3drm);
|
||||||
|
|
||||||
|
if (texture->image)
|
||||||
|
return D3DRMERR_BADOBJECT;
|
||||||
|
|
||||||
|
texture->image = image;
|
||||||
|
|
||||||
|
return D3DRM_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI d3drm_texture3_InitFromResource2(IDirect3DRMTexture3 *iface,
|
static HRESULT WINAPI d3drm_texture3_InitFromResource2(IDirect3DRMTexture3 *iface,
|
||||||
|
|
Loading…
Reference in New Issue