Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
a36f7015
Commit
a36f7015
authored
Mar 17, 2023
by
Mohamad Al-Jaf
Committed by
Alexandre Julliard
Mar 27, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
graphicscapture: Add IGraphicsCaptureSessionStatics stub interface.
parent
14768c0e
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
74 additions
and
0 deletions
+74
-0
private.h
dlls/graphicscapture/private.h
+38
-0
session.c
dlls/graphicscapture/session.c
+30
-0
graphicscapture.c
dlls/graphicscapture/tests/graphicscapture.c
+6
-0
No files found.
dlls/graphicscapture/private.h
View file @
a36f7015
...
...
@@ -36,4 +36,42 @@
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
dlls/graphicscapture/session.c
View file @
a36f7015
...
...
@@ -25,6 +25,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(graphicscapture);
struct
session
{
IActivationFactory
IActivationFactory_iface
;
IGraphicsCaptureSessionStatics
IGraphicsCaptureSessionStatics_iface
;
LONG
ref
;
};
...
...
@@ -49,6 +50,13 @@ static HRESULT WINAPI factory_QueryInterface( IActivationFactory *iface, REFIID
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
)
);
*
out
=
NULL
;
return
E_NOINTERFACE
;
...
...
@@ -107,9 +115,31 @@ static const struct IActivationFactoryVtbl factory_vtbl =
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
=
{
{
&
factory_vtbl
},
{
&
session_statics_vtbl
},
0
,
};
...
...
dlls/graphicscapture/tests/graphicscapture.c
View file @
a36f7015
...
...
@@ -47,6 +47,7 @@ static void check_interface_( unsigned int line, void *obj, const IID *iid )
static
void
test_GraphicsCaptureSessionStatics
(
void
)
{
static
const
WCHAR
*
session_statics_name
=
L"Windows.Graphics.Capture.GraphicsCaptureSession"
;
IGraphicsCaptureSessionStatics
*
session_statics
;
IActivationFactory
*
factory
;
HSTRING
str
;
HRESULT
hr
;
...
...
@@ -68,6 +69,11 @@ static void test_GraphicsCaptureSessionStatics(void)
check_interface
(
factory
,
&
IID_IInspectable
);
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
);
ok
(
ref
==
0
,
"got ref %ld.
\n
"
,
ref
);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment