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
245649f8
Commit
245649f8
authored
Jun 11, 2019
by
Zebediah Figura
Committed by
Alexandre Julliard
Jun 11, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
quartz/filtergraph: Use the type info cache for IVideoWindow.
Signed-off-by:
Zebediah Figura
<
z.figura12@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
014012dd
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
33 additions
and
68 deletions
+33
-68
filtergraph.c
dlls/quartz/filtergraph.c
+28
-68
filtergraph.c
dlls/quartz/tests/filtergraph.c
+5
-0
No files found.
dlls/quartz/filtergraph.c
View file @
245649f8
...
@@ -4066,94 +4066,54 @@ static ULONG WINAPI VideoWindow_Release(IVideoWindow *iface)
...
@@ -4066,94 +4066,54 @@ static ULONG WINAPI VideoWindow_Release(IVideoWindow *iface)
return
IUnknown_Release
(
This
->
outer_unk
);
return
IUnknown_Release
(
This
->
outer_unk
);
}
}
/*** IDispatch methods ***/
HRESULT
WINAPI
VideoWindow_GetTypeInfoCount
(
IVideoWindow
*
iface
,
UINT
*
count
)
static
HRESULT
WINAPI
VideoWindow_GetTypeInfoCount
(
IVideoWindow
*
iface
,
UINT
*
pctinfo
)
{
{
IFilterGraphImpl
*
This
=
impl_from_IVideoWindow
(
iface
);
TRACE
(
"iface %p, count %p.
\n
"
,
iface
,
count
);
IVideoWindow
*
pVideoWindow
;
*
count
=
1
;
HRESULT
hr
;
return
S_OK
;
TRACE
(
"(%p/%p)->(%p)
\n
"
,
This
,
iface
,
pctinfo
);
EnterCriticalSection
(
&
This
->
cs
);
hr
=
GetTargetInterface
(
This
,
&
IID_IVideoWindow
,
(
LPVOID
*
)
&
pVideoWindow
);
if
(
hr
==
S_OK
)
hr
=
IVideoWindow_GetTypeInfoCount
(
pVideoWindow
,
pctinfo
);
LeaveCriticalSection
(
&
This
->
cs
);
return
hr
;
}
}
static
HRESULT
WINAPI
VideoWindow_GetTypeInfo
(
IVideoWindow
*
iface
,
UINT
iTInfo
,
LCID
lcid
,
HRESULT
WINAPI
VideoWindow_GetTypeInfo
(
IVideoWindow
*
iface
,
UINT
index
,
ITypeInfo
**
ppTI
nfo
)
LCID
lcid
,
ITypeInfo
**
typei
nfo
)
{
{
IFilterGraphImpl
*
This
=
impl_from_IVideoWindow
(
iface
);
TRACE
(
"iface %p, index %u, lcid %#x, typeinfo %p.
\n
"
,
iface
,
index
,
lcid
,
typeinfo
);
IVideoWindow
*
pVideoWindow
;
return
strmbase_get_typeinfo
(
IVideoWindow_tid
,
typeinfo
);
HRESULT
hr
;
TRACE
(
"(%p/%p)->(%d, %d, %p)
\n
"
,
This
,
iface
,
iTInfo
,
lcid
,
ppTInfo
);
EnterCriticalSection
(
&
This
->
cs
);
hr
=
GetTargetInterface
(
This
,
&
IID_IVideoWindow
,
(
LPVOID
*
)
&
pVideoWindow
);
if
(
hr
==
S_OK
)
hr
=
IVideoWindow_GetTypeInfo
(
pVideoWindow
,
iTInfo
,
lcid
,
ppTInfo
);
LeaveCriticalSection
(
&
This
->
cs
);
return
hr
;
}
}
static
HRESULT
WINAPI
VideoWindow_GetIDsOfNames
(
IVideoWindow
*
iface
,
REFIID
r
iid
,
HRESULT
WINAPI
VideoWindow_GetIDsOfNames
(
IVideoWindow
*
iface
,
REFIID
iid
,
LPOLESTR
*
rgszNames
,
UINT
cNames
,
LCID
lcid
,
DISPID
*
rgDispId
)
LPOLESTR
*
names
,
UINT
count
,
LCID
lcid
,
DISPID
*
ids
)
{
{
IFilterGraphImpl
*
This
=
impl_from_IVideoWindow
(
iface
);
ITypeInfo
*
typeinfo
;
IVideoWindow
*
pVideoWindow
;
HRESULT
hr
;
HRESULT
hr
;
TRACE
(
"(%p/%p)->(%s, %p, %d, %d, %p)
\n
"
,
This
,
iface
,
debugstr_guid
(
riid
),
rgszNames
,
cNames
,
TRACE
(
"iface %p, iid %s, names %p, count %u, lcid %#x, ids %p.
\n
"
,
lcid
,
rgDispId
);
iface
,
debugstr_guid
(
iid
),
names
,
count
,
lcid
,
ids
);
EnterCriticalSection
(
&
This
->
cs
);
hr
=
GetTargetInterface
(
This
,
&
IID_IVideoWindow
,
(
LPVOID
*
)
&
pVideoWindow
);
if
(
hr
==
S_OK
)
hr
=
IVideoWindow_GetIDsOfNames
(
pVideoWindow
,
riid
,
rgszNames
,
cNames
,
lcid
,
rgDispId
);
LeaveCriticalSection
(
&
This
->
cs
);
if
(
SUCCEEDED
(
hr
=
strmbase_get_typeinfo
(
IVideoWindow_tid
,
&
typeinfo
)))
{
hr
=
ITypeInfo_GetIDsOfNames
(
typeinfo
,
names
,
count
,
ids
);
ITypeInfo_Release
(
typeinfo
);
}
return
hr
;
return
hr
;
}
}
static
HRESULT
WINAPI
VideoWindow_Invoke
(
IVideoWindow
*
iface
,
DISPID
dispIdMember
,
REFIID
riid
,
static
HRESULT
WINAPI
VideoWindow_Invoke
(
IVideoWindow
*
iface
,
DISPID
id
,
REFIID
iid
,
LCID
lcid
,
LCID
lcid
,
WORD
wFlags
,
DISPPARAMS
*
pDispParams
,
VARIANT
*
pVarResult
,
EXCEPINFO
*
pExepInfo
,
WORD
flags
,
DISPPARAMS
*
params
,
VARIANT
*
result
,
EXCEPINFO
*
excepinfo
,
UINT
*
error_arg
)
UINT
*
puArgErr
)
{
{
IFilterGraphImpl
*
This
=
impl_from_IVideoWindow
(
iface
);
ITypeInfo
*
typeinfo
;
IVideoWindow
*
pVideoWindow
;
HRESULT
hr
;
HRESULT
hr
;
TRACE
(
"(%p/%p)->(%d, %s, %d, %04x, %p, %p, %p, %p)
\n
"
,
This
,
iface
,
dispIdMember
,
TRACE
(
"iface %p, id %d, iid %s, lcid %#x, flags %#x, params %p, result %p, excepinfo %p, error_arg %p.
\n
"
,
debugstr_guid
(
riid
),
lcid
,
wFlags
,
pDispParams
,
pVarResult
,
pExepInfo
,
puArgErr
);
iface
,
id
,
debugstr_guid
(
iid
),
lcid
,
flags
,
params
,
result
,
excepinfo
,
error_arg
);
EnterCriticalSection
(
&
This
->
cs
);
hr
=
GetTargetInterface
(
This
,
&
IID_IVideoWindow
,
(
LPVOID
*
)
&
pVideoWindow
);
if
(
hr
==
S_OK
)
hr
=
IVideoWindow_Invoke
(
pVideoWindow
,
dispIdMember
,
riid
,
lcid
,
wFlags
,
pDispParams
,
pVarResult
,
pExepInfo
,
puArgErr
);
LeaveCriticalSection
(
&
This
->
cs
);
if
(
SUCCEEDED
(
hr
=
strmbase_get_typeinfo
(
IVideoWindow_tid
,
&
typeinfo
)))
{
hr
=
ITypeInfo_Invoke
(
typeinfo
,
iface
,
id
,
flags
,
params
,
result
,
excepinfo
,
error_arg
);
ITypeInfo_Release
(
typeinfo
);
}
return
hr
;
return
hr
;
}
}
/*** IVideoWindow methods ***/
/*** IVideoWindow methods ***/
static
HRESULT
WINAPI
VideoWindow_put_Caption
(
IVideoWindow
*
iface
,
BSTR
strCaption
)
static
HRESULT
WINAPI
VideoWindow_put_Caption
(
IVideoWindow
*
iface
,
BSTR
strCaption
)
{
{
...
...
dlls/quartz/tests/filtergraph.c
View file @
245649f8
...
@@ -2572,9 +2572,14 @@ static void test_control_delegation(void)
...
@@ -2572,9 +2572,14 @@ static void test_control_delegation(void)
/* Unlike IBasicAudio, these return E_NOINTERFACE. */
/* Unlike IBasicAudio, these return E_NOINTERFACE. */
hr
=
IBasicVideo_get_BitRate
(
video
,
&
val
);
hr
=
IBasicVideo_get_BitRate
(
video
,
&
val
);
ok
(
hr
==
E_NOINTERFACE
,
"got %#x
\n
"
,
hr
);
ok
(
hr
==
E_NOINTERFACE
,
"got %#x
\n
"
,
hr
);
hr
=
IVideoWindow_SetWindowForeground
(
window
,
OAFALSE
);
hr
=
IVideoWindow_SetWindowForeground
(
window
,
OAFALSE
);
ok
(
hr
==
E_NOINTERFACE
,
"got %#x
\n
"
,
hr
);
ok
(
hr
==
E_NOINTERFACE
,
"got %#x
\n
"
,
hr
);
hr
=
IVideoWindow_GetTypeInfoCount
(
window
,
&
count
);
ok
(
hr
==
S_OK
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
count
==
1
,
"Got count %u.
\n
"
,
count
);
hr
=
CoCreateInstance
(
&
CLSID_VideoRenderer
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IBaseFilter
,
(
void
**
)
&
renderer
);
hr
=
CoCreateInstance
(
&
CLSID_VideoRenderer
,
NULL
,
CLSCTX_INPROC_SERVER
,
&
IID_IBaseFilter
,
(
void
**
)
&
renderer
);
ok
(
hr
==
S_OK
,
"got %#x
\n
"
,
hr
);
ok
(
hr
==
S_OK
,
"got %#x
\n
"
,
hr
);
...
...
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