Commit a36f7015 authored by Mohamad Al-Jaf's avatar Mohamad Al-Jaf Committed by Alexandre Julliard

graphicscapture: Add IGraphicsCaptureSessionStatics stub interface.

parent 14768c0e
...@@ -36,4 +36,42 @@ ...@@ -36,4 +36,42 @@
extern IActivationFactory *session_factory; extern IActivationFactory *session_factory;
#define DEFINE_IINSPECTABLE_( pfx, iface_type, impl_type, impl_from, iface_mem, expr ) \
static inline impl_type *impl_from( iface_type *iface ) \
{ \
return CONTAINING_RECORD( iface, impl_type, iface_mem ); \
} \
static HRESULT WINAPI pfx##_QueryInterface( iface_type *iface, REFIID iid, void **out ) \
{ \
impl_type *impl = impl_from( iface ); \
return IInspectable_QueryInterface( (IInspectable *)(expr), iid, out ); \
} \
static ULONG WINAPI pfx##_AddRef( iface_type *iface ) \
{ \
impl_type *impl = impl_from( iface ); \
return IInspectable_AddRef( (IInspectable *)(expr) ); \
} \
static ULONG WINAPI pfx##_Release( iface_type *iface ) \
{ \
impl_type *impl = impl_from( iface ); \
return IInspectable_Release( (IInspectable *)(expr) ); \
} \
static HRESULT WINAPI pfx##_GetIids( iface_type *iface, ULONG *iid_count, IID **iids ) \
{ \
impl_type *impl = impl_from( iface ); \
return IInspectable_GetIids( (IInspectable *)(expr), iid_count, iids ); \
} \
static HRESULT WINAPI pfx##_GetRuntimeClassName( iface_type *iface, HSTRING *class_name ) \
{ \
impl_type *impl = impl_from( iface ); \
return IInspectable_GetRuntimeClassName( (IInspectable *)(expr), class_name ); \
} \
static HRESULT WINAPI pfx##_GetTrustLevel( iface_type *iface, TrustLevel *trust_level ) \
{ \
impl_type *impl = impl_from( iface ); \
return IInspectable_GetTrustLevel( (IInspectable *)(expr), trust_level ); \
}
#define DEFINE_IINSPECTABLE( pfx, iface_type, impl_type, base_iface ) \
DEFINE_IINSPECTABLE_( pfx, iface_type, impl_type, impl_from_##iface_type, iface_type##_iface, &impl->base_iface )
#endif #endif
...@@ -25,6 +25,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(graphicscapture); ...@@ -25,6 +25,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(graphicscapture);
struct session struct session
{ {
IActivationFactory IActivationFactory_iface; IActivationFactory IActivationFactory_iface;
IGraphicsCaptureSessionStatics IGraphicsCaptureSessionStatics_iface;
LONG ref; LONG ref;
}; };
...@@ -49,6 +50,13 @@ static HRESULT WINAPI factory_QueryInterface( IActivationFactory *iface, REFIID ...@@ -49,6 +50,13 @@ static HRESULT WINAPI factory_QueryInterface( IActivationFactory *iface, REFIID
return S_OK; return S_OK;
} }
if (IsEqualGUID( iid, &IID_IGraphicsCaptureSessionStatics ))
{
*out = &impl->IGraphicsCaptureSessionStatics_iface;
IInspectable_AddRef( *out );
return S_OK;
}
FIXME( "%s not implemented, returning E_NOINTERFACE.\n", debugstr_guid( iid ) ); FIXME( "%s not implemented, returning E_NOINTERFACE.\n", debugstr_guid( iid ) );
*out = NULL; *out = NULL;
return E_NOINTERFACE; return E_NOINTERFACE;
...@@ -107,9 +115,31 @@ static const struct IActivationFactoryVtbl factory_vtbl = ...@@ -107,9 +115,31 @@ static const struct IActivationFactoryVtbl factory_vtbl =
factory_ActivateInstance, factory_ActivateInstance,
}; };
DEFINE_IINSPECTABLE( session_statics, IGraphicsCaptureSessionStatics, struct session, IActivationFactory_iface )
static HRESULT WINAPI session_statics_IsSupported( IGraphicsCaptureSessionStatics *iface, boolean *result )
{
FIXME( "iface %p, result %p stub!\n", iface, result );
return E_NOTIMPL;
}
static const struct IGraphicsCaptureSessionStaticsVtbl session_statics_vtbl =
{
session_statics_QueryInterface,
session_statics_AddRef,
session_statics_Release,
/* IInspectable methods */
session_statics_GetIids,
session_statics_GetRuntimeClassName,
session_statics_GetTrustLevel,
/* IGraphicsCaptureSessionStatics methods */
session_statics_IsSupported,
};
static struct session session_statics = static struct session session_statics =
{ {
{&factory_vtbl}, {&factory_vtbl},
{&session_statics_vtbl},
0, 0,
}; };
......
...@@ -47,6 +47,7 @@ static void check_interface_( unsigned int line, void *obj, const IID *iid ) ...@@ -47,6 +47,7 @@ static void check_interface_( unsigned int line, void *obj, const IID *iid )
static void test_GraphicsCaptureSessionStatics(void) static void test_GraphicsCaptureSessionStatics(void)
{ {
static const WCHAR *session_statics_name = L"Windows.Graphics.Capture.GraphicsCaptureSession"; static const WCHAR *session_statics_name = L"Windows.Graphics.Capture.GraphicsCaptureSession";
IGraphicsCaptureSessionStatics *session_statics;
IActivationFactory *factory; IActivationFactory *factory;
HSTRING str; HSTRING str;
HRESULT hr; HRESULT hr;
...@@ -68,6 +69,11 @@ static void test_GraphicsCaptureSessionStatics(void) ...@@ -68,6 +69,11 @@ static void test_GraphicsCaptureSessionStatics(void)
check_interface( factory, &IID_IInspectable ); check_interface( factory, &IID_IInspectable );
check_interface( factory, &IID_IAgileObject ); check_interface( factory, &IID_IAgileObject );
hr = IActivationFactory_QueryInterface( factory, &IID_IGraphicsCaptureSessionStatics, (void **)&session_statics );
ok( hr == S_OK, "got hr %#lx.\n", hr );
ref = IGraphicsCaptureSessionStatics_Release( session_statics );
ok( ref == 1, "got ref %ld.\n", ref );
ref = IActivationFactory_Release( factory ); ref = IActivationFactory_Release( factory );
ok( ref == 0, "got ref %ld.\n", ref ); ok( ref == 0, "got ref %ld.\n", ref );
} }
......
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