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
71967608
Commit
71967608
authored
Jan 24, 2020
by
Zebediah Figura
Committed by
Alexandre Julliard
Jan 24, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winegstreamer: Implement IPin::QueryAccept() for the WAVE parser source.
Signed-off-by:
Zebediah Figura
<
z.figura12@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
44ef5177
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
44 additions
and
9 deletions
+44
-9
waveparser.c
dlls/quartz/tests/waveparser.c
+6
-6
gstdemux.c
dlls/winegstreamer/gstdemux.c
+38
-3
No files found.
dlls/quartz/tests/waveparser.c
View file @
71967608
...
@@ -606,20 +606,20 @@ static void test_media_types(void)
...
@@ -606,20 +606,20 @@ static void test_media_types(void)
pmt
->
majortype
=
GUID_NULL
;
pmt
->
majortype
=
GUID_NULL
;
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
todo_wine
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
pmt
->
majortype
=
MEDIATYPE_Audio
;
pmt
->
majortype
=
MEDIATYPE_Audio
;
pmt
->
subtype
=
GUID_NULL
;
pmt
->
subtype
=
GUID_NULL
;
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
todo_wine
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
pmt
->
subtype
=
MEDIASUBTYPE_WAVE
;
pmt
->
subtype
=
MEDIASUBTYPE_WAVE
;
pmt
->
formattype
=
GUID_NULL
;
pmt
->
formattype
=
GUID_NULL
;
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
todo_wine
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
pmt
->
formattype
=
FORMAT_None
;
pmt
->
formattype
=
FORMAT_None
;
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
todo_wine
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
wfx
=
(
WAVEFORMATEX
*
)
pmt
->
pbFormat
;
wfx
=
(
WAVEFORMATEX
*
)
pmt
->
pbFormat
;
...
@@ -627,12 +627,12 @@ static void test_media_types(void)
...
@@ -627,12 +627,12 @@ static void test_media_types(void)
wfx
->
nAvgBytesPerSec
=
44100
*
2
;
wfx
->
nAvgBytesPerSec
=
44100
*
2
;
wfx
->
nBlockAlign
=
2
;
wfx
->
nBlockAlign
=
2
;
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
todo_wine
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
*
wfx
=
expect_wfx
;
*
wfx
=
expect_wfx
;
wfx
->
wFormatTag
=
WAVE_FORMAT_IMA_ADPCM
;
wfx
->
wFormatTag
=
WAVE_FORMAT_IMA_ADPCM
;
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
hr
=
IPin_QueryAccept
(
pin
,
pmt
);
todo_wine
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
ok
(
hr
==
S_FALSE
,
"Got hr %#x.
\n
"
,
hr
);
*
wfx
=
expect_wfx
;
*
wfx
=
expect_wfx
;
CoTaskMemFree
(
pmt
->
pbFormat
);
CoTaskMemFree
(
pmt
->
pbFormat
);
...
...
dlls/winegstreamer/gstdemux.c
View file @
71967608
...
@@ -75,6 +75,7 @@ struct gstdemux
...
@@ -75,6 +75,7 @@ struct gstdemux
HANDLE
push_thread
;
HANDLE
push_thread
;
BOOL
(
*
init_gst
)(
struct
gstdemux
*
filter
);
BOOL
(
*
init_gst
)(
struct
gstdemux
*
filter
);
HRESULT
(
*
source_query_accept
)(
struct
gstdemux_source
*
pin
,
const
AM_MEDIA_TYPE
*
mt
);
};
};
struct
gstdemux_source
struct
gstdemux_source
...
@@ -1531,6 +1532,11 @@ static BOOL gstdecoder_init_gst(struct gstdemux *filter)
...
@@ -1531,6 +1532,11 @@ static BOOL gstdecoder_init_gst(struct gstdemux *filter)
return
TRUE
;
return
TRUE
;
}
}
static
HRESULT
gstdecoder_source_query_accept
(
struct
gstdemux_source
*
pin
,
const
AM_MEDIA_TYPE
*
mt
)
{
return
S_OK
;
}
IUnknown
*
CALLBACK
Gstreamer_Splitter_create
(
IUnknown
*
outer
,
HRESULT
*
phr
)
IUnknown
*
CALLBACK
Gstreamer_Splitter_create
(
IUnknown
*
outer
,
HRESULT
*
phr
)
{
{
struct
gstdemux
*
object
;
struct
gstdemux
*
object
;
...
@@ -1555,6 +1561,7 @@ IUnknown * CALLBACK Gstreamer_Splitter_create(IUnknown *outer, HRESULT *phr)
...
@@ -1555,6 +1561,7 @@ IUnknown * CALLBACK Gstreamer_Splitter_create(IUnknown *outer, HRESULT *phr)
object
->
no_more_pads_event
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
object
->
no_more_pads_event
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
init_gst
=
gstdecoder_init_gst
;
object
->
init_gst
=
gstdecoder_init_gst
;
object
->
source_query_accept
=
gstdecoder_source_query_accept
;
*
phr
=
S_OK
;
*
phr
=
S_OK
;
TRACE
(
"Created GStreamer demuxer %p.
\n
"
,
object
);
TRACE
(
"Created GStreamer demuxer %p.
\n
"
,
object
);
...
@@ -1859,10 +1866,11 @@ static HRESULT source_query_interface(struct strmbase_pin *iface, REFIID iid, vo
...
@@ -1859,10 +1866,11 @@ static HRESULT source_query_interface(struct strmbase_pin *iface, REFIID iid, vo
return
S_OK
;
return
S_OK
;
}
}
static
HRESULT
source_query_accept
(
struct
strmbase_pin
*
base
,
const
AM_MEDIA_TYPE
*
a
mt
)
static
HRESULT
source_query_accept
(
struct
strmbase_pin
*
iface
,
const
AM_MEDIA_TYPE
*
mt
)
{
{
FIXME
(
"(%p) stub
\n
"
,
base
);
struct
gstdemux_source
*
pin
=
impl_source_from_IPin
(
&
iface
->
IPin_iface
);
return
S_OK
;
struct
gstdemux
*
filter
=
impl_from_strmbase_filter
(
iface
->
filter
);
return
filter
->
source_query_accept
(
pin
,
mt
);
}
}
static
HRESULT
source_get_media_type
(
struct
strmbase_pin
*
iface
,
unsigned
int
iPosition
,
AM_MEDIA_TYPE
*
pmt
)
static
HRESULT
source_get_media_type
(
struct
strmbase_pin
*
iface
,
unsigned
int
iPosition
,
AM_MEDIA_TYPE
*
pmt
)
...
@@ -2164,6 +2172,15 @@ void start_dispatch_thread(void)
...
@@ -2164,6 +2172,15 @@ void start_dispatch_thread(void)
CloseHandle
(
CreateThread
(
NULL
,
0
,
&
dispatch_thread
,
NULL
,
0
,
NULL
));
CloseHandle
(
CreateThread
(
NULL
,
0
,
&
dispatch_thread
,
NULL
,
0
,
NULL
));
}
}
static
BOOL
compare_media_types
(
const
AM_MEDIA_TYPE
*
a
,
const
AM_MEDIA_TYPE
*
b
)
{
return
IsEqualGUID
(
&
a
->
majortype
,
&
b
->
majortype
)
&&
IsEqualGUID
(
&
a
->
subtype
,
&
b
->
subtype
)
&&
IsEqualGUID
(
&
a
->
formattype
,
&
b
->
formattype
)
&&
a
->
cbFormat
==
b
->
cbFormat
&&
!
memcmp
(
a
->
pbFormat
,
b
->
pbFormat
,
a
->
cbFormat
);
}
static
HRESULT
wave_parser_sink_query_accept
(
struct
strmbase_pin
*
iface
,
const
AM_MEDIA_TYPE
*
mt
)
static
HRESULT
wave_parser_sink_query_accept
(
struct
strmbase_pin
*
iface
,
const
AM_MEDIA_TYPE
*
mt
)
{
{
if
(
!
IsEqualGUID
(
&
mt
->
majortype
,
&
MEDIATYPE_Stream
))
if
(
!
IsEqualGUID
(
&
mt
->
majortype
,
&
MEDIATYPE_Stream
))
...
@@ -2246,6 +2263,11 @@ static BOOL wave_parser_init_gst(struct gstdemux *filter)
...
@@ -2246,6 +2263,11 @@ static BOOL wave_parser_init_gst(struct gstdemux *filter)
return
TRUE
;
return
TRUE
;
}
}
static
HRESULT
wave_parser_source_query_accept
(
struct
gstdemux_source
*
pin
,
const
AM_MEDIA_TYPE
*
mt
)
{
return
compare_media_types
(
mt
,
&
pin
->
mt
)
?
S_OK
:
S_FALSE
;
}
IUnknown
*
CALLBACK
wave_parser_create
(
IUnknown
*
outer
,
HRESULT
*
phr
)
IUnknown
*
CALLBACK
wave_parser_create
(
IUnknown
*
outer
,
HRESULT
*
phr
)
{
{
static
const
WCHAR
sink_name
[]
=
{
'i'
,
'n'
,
'p'
,
'u'
,
't'
,
' '
,
'p'
,
'i'
,
'n'
,
0
};
static
const
WCHAR
sink_name
[]
=
{
'i'
,
'n'
,
'p'
,
'u'
,
't'
,
' '
,
'p'
,
'i'
,
'n'
,
0
};
...
@@ -2269,6 +2291,7 @@ IUnknown * CALLBACK wave_parser_create(IUnknown *outer, HRESULT *phr)
...
@@ -2269,6 +2291,7 @@ IUnknown * CALLBACK wave_parser_create(IUnknown *outer, HRESULT *phr)
strmbase_sink_init
(
&
object
->
sink
,
&
object
->
filter
,
sink_name
,
&
wave_parser_sink_ops
,
NULL
);
strmbase_sink_init
(
&
object
->
sink
,
&
object
->
filter
,
sink_name
,
&
wave_parser_sink_ops
,
NULL
);
object
->
init_gst
=
wave_parser_init_gst
;
object
->
init_gst
=
wave_parser_init_gst
;
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
source_query_accept
=
wave_parser_source_query_accept
;
*
phr
=
S_OK
;
*
phr
=
S_OK
;
TRACE
(
"Created WAVE parser %p.
\n
"
,
object
);
TRACE
(
"Created WAVE parser %p.
\n
"
,
object
);
...
@@ -2352,6 +2375,11 @@ static BOOL avi_splitter_init_gst(struct gstdemux *filter)
...
@@ -2352,6 +2375,11 @@ static BOOL avi_splitter_init_gst(struct gstdemux *filter)
return
TRUE
;
return
TRUE
;
}
}
static
HRESULT
avi_splitter_source_query_accept
(
struct
gstdemux_source
*
pin
,
const
AM_MEDIA_TYPE
*
mt
)
{
return
S_OK
;
}
IUnknown
*
CALLBACK
avi_splitter_create
(
IUnknown
*
outer
,
HRESULT
*
phr
)
IUnknown
*
CALLBACK
avi_splitter_create
(
IUnknown
*
outer
,
HRESULT
*
phr
)
{
{
static
const
WCHAR
sink_name
[]
=
{
'i'
,
'n'
,
'p'
,
'u'
,
't'
,
' '
,
'p'
,
'i'
,
'n'
,
0
};
static
const
WCHAR
sink_name
[]
=
{
'i'
,
'n'
,
'p'
,
'u'
,
't'
,
' '
,
'p'
,
'i'
,
'n'
,
0
};
...
@@ -2376,6 +2404,7 @@ IUnknown * CALLBACK avi_splitter_create(IUnknown *outer, HRESULT *phr)
...
@@ -2376,6 +2404,7 @@ IUnknown * CALLBACK avi_splitter_create(IUnknown *outer, HRESULT *phr)
object
->
no_more_pads_event
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
object
->
no_more_pads_event
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
init_gst
=
avi_splitter_init_gst
;
object
->
init_gst
=
avi_splitter_init_gst
;
object
->
source_query_accept
=
avi_splitter_source_query_accept
;
*
phr
=
S_OK
;
*
phr
=
S_OK
;
TRACE
(
"Created AVI splitter %p.
\n
"
,
object
);
TRACE
(
"Created AVI splitter %p.
\n
"
,
object
);
...
@@ -2469,6 +2498,11 @@ static BOOL mpeg_splitter_init_gst(struct gstdemux *filter)
...
@@ -2469,6 +2498,11 @@ static BOOL mpeg_splitter_init_gst(struct gstdemux *filter)
return
TRUE
;
return
TRUE
;
}
}
static
HRESULT
mpeg_splitter_source_query_accept
(
struct
gstdemux_source
*
pin
,
const
AM_MEDIA_TYPE
*
mt
)
{
return
S_OK
;
}
static
HRESULT
mpeg_splitter_query_interface
(
struct
strmbase_filter
*
iface
,
REFIID
iid
,
void
**
out
)
static
HRESULT
mpeg_splitter_query_interface
(
struct
strmbase_filter
*
iface
,
REFIID
iid
,
void
**
out
)
{
{
struct
gstdemux
*
filter
=
impl_from_strmbase_filter
(
iface
);
struct
gstdemux
*
filter
=
impl_from_strmbase_filter
(
iface
);
...
@@ -2521,6 +2555,7 @@ IUnknown * CALLBACK mpeg_splitter_create(IUnknown *outer, HRESULT *phr)
...
@@ -2521,6 +2555,7 @@ IUnknown * CALLBACK mpeg_splitter_create(IUnknown *outer, HRESULT *phr)
object
->
duration_event
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
object
->
duration_event
=
CreateEventW
(
NULL
,
FALSE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
error_event
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
object
->
init_gst
=
mpeg_splitter_init_gst
;
object
->
init_gst
=
mpeg_splitter_init_gst
;
object
->
source_query_accept
=
mpeg_splitter_source_query_accept
;
object
->
enum_sink_first
=
TRUE
;
object
->
enum_sink_first
=
TRUE
;
*
phr
=
S_OK
;
*
phr
=
S_OK
;
...
...
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