Commit c172b895 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

d2d1: Move effect object creation to effect.c.

parent 8eff207c
...@@ -624,8 +624,8 @@ struct d2d_effect ...@@ -624,8 +624,8 @@ struct d2d_effect
size_t input_count; size_t input_count;
}; };
HRESULT d2d_effect_init(struct d2d_effect *effect, HRESULT d2d_effect_create(struct d2d_device_context *context, const CLSID *effect_id,
struct d2d_effect_context *effect_context, const CLSID *effect_id) DECLSPEC_HIDDEN; ID2D1Effect **effect) DECLSPEC_HIDDEN;
static inline BOOL d2d_array_reserve(void **elements, size_t *capacity, size_t count, size_t size) static inline BOOL d2d_array_reserve(void **elements, size_t *capacity, size_t count, size_t size)
{ {
......
...@@ -1946,36 +1946,10 @@ static HRESULT STDMETHODCALLTYPE d2d_device_context_CreateEffect(ID2D1DeviceCont ...@@ -1946,36 +1946,10 @@ static HRESULT STDMETHODCALLTYPE d2d_device_context_CreateEffect(ID2D1DeviceCont
REFCLSID effect_id, ID2D1Effect **effect) REFCLSID effect_id, ID2D1Effect **effect)
{ {
struct d2d_device_context *context = impl_from_ID2D1DeviceContext(iface); struct d2d_device_context *context = impl_from_ID2D1DeviceContext(iface);
struct d2d_effect_context *effect_context;
struct d2d_effect *object;
HRESULT hr;
TRACE("iface %p, effect_id %s, effect %p.\n", iface, debugstr_guid(effect_id), effect); TRACE("iface %p, effect_id %s, effect %p.\n", iface, debugstr_guid(effect_id), effect);
if (!(effect_context = calloc(1, sizeof(*effect_context)))) return d2d_effect_create(context, effect_id, effect);
return E_OUTOFMEMORY;
d2d_effect_context_init(effect_context, context);
if (!(object = calloc(1, sizeof(*object))))
{
ID2D1EffectContext_Release(&effect_context->ID2D1EffectContext_iface);
return E_OUTOFMEMORY;
}
hr = d2d_effect_init(object, effect_context, effect_id);
ID2D1EffectContext_Release(&effect_context->ID2D1EffectContext_iface);
if (FAILED(hr))
{
WARN("Failed to initialise effect, hr %#lx.\n", hr);
free(object);
return hr;
}
*effect = &object->ID2D1Effect_iface;
TRACE("Created effect %p.\n", *effect);
return S_OK;
} }
static HRESULT STDMETHODCALLTYPE d2d_device_context_ID2D1DeviceContext_CreateGradientStopCollection( static HRESULT STDMETHODCALLTYPE d2d_device_context_ID2D1DeviceContext_CreateGradientStopCollection(
......
...@@ -753,26 +753,47 @@ static const ID2D1ImageVtbl d2d_effect_image_vtbl = ...@@ -753,26 +753,47 @@ static const ID2D1ImageVtbl d2d_effect_image_vtbl =
d2d_effect_image_GetFactory, d2d_effect_image_GetFactory,
}; };
HRESULT d2d_effect_init(struct d2d_effect *effect, struct d2d_effect_context *effect_context, const CLSID *effect_id) HRESULT d2d_effect_create(struct d2d_device_context *context, const CLSID *effect_id,
ID2D1Effect **effect)
{ {
struct d2d_effect_context *effect_context;
struct d2d_effect *object;
unsigned int i; unsigned int i;
effect->ID2D1Effect_iface.lpVtbl = &d2d_effect_vtbl; if (!(effect_context = calloc(1, sizeof(*effect_context))))
effect->ID2D1Image_iface.lpVtbl = &d2d_effect_image_vtbl; return E_OUTOFMEMORY;
effect->refcount = 1; d2d_effect_context_init(effect_context, context);
if (!(object = calloc(1, sizeof(*object))))
{
ID2D1EffectContext_Release(&effect_context->ID2D1EffectContext_iface);
return E_OUTOFMEMORY;
}
object->ID2D1Effect_iface.lpVtbl = &d2d_effect_vtbl;
object->ID2D1Image_iface.lpVtbl = &d2d_effect_image_vtbl;
object->refcount = 1;
object->effect_context = effect_context;
for (i = 0; i < ARRAY_SIZE(builtin_effects); ++i) for (i = 0; i < ARRAY_SIZE(builtin_effects); ++i)
{ {
if (IsEqualGUID(effect_id, builtin_effects[i].clsid)) if (IsEqualGUID(effect_id, builtin_effects[i].clsid))
{ {
effect->info = &builtin_effects[i]; object->info = &builtin_effects[i];
d2d_effect_SetInputCount(&effect->ID2D1Effect_iface, effect->info->default_input_count); d2d_effect_SetInputCount(&object->ID2D1Effect_iface, object->info->default_input_count);
effect->effect_context = effect_context; break;
ID2D1EffectContext_AddRef(&effect_context->ID2D1EffectContext_iface);
return S_OK;
} }
} }
WARN("Unsupported effect clsid %s.\n", debugstr_guid(effect_id)); if (i == ARRAY_SIZE(builtin_effects))
return E_FAIL; {
ID2D1Effect_Release(&object->ID2D1Effect_iface);
return E_FAIL;
}
*effect = &object->ID2D1Effect_iface;
TRACE("Created effect %p.\n", *effect);
return S_OK;
} }
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