[PATCH 3/3] amstream: Implement IMediaStreamFilter::GetStopPosition.
Zebediah Figura
zfigura at codeweavers.com
Fri Jul 24 10:18:17 CDT 2020
On 7/24/20 1:24 AM, Myah Caron wrote:
> Signed-off-by: Myah Caron <qsniyg at protonmail.com>
> ---
> dlls/amstream/filter.c | 24 ++++++++++++++++++++++--
> dlls/amstream/tests/amstream.c | 15 ++++++++++++---
> 2 files changed, 34 insertions(+), 5 deletions(-)
>
> diff --git a/dlls/amstream/filter.c b/dlls/amstream/filter.c
> index ef23edfae3..6d1b107df5 100644
> --- a/dlls/amstream/filter.c
> +++ b/dlls/amstream/filter.c
> @@ -800,9 +800,29 @@ static HRESULT WINAPI filter_seeking_GetDuration(IMediaSeeking *iface, LONGLONG
>
> static HRESULT WINAPI filter_seeking_GetStopPosition(IMediaSeeking *iface, LONGLONG *stop)
> {
> - FIXME("iface %p, stop %p, stub!\n", iface, stop);
> + struct filter *filter = impl_from_IMediaSeeking(iface);
> + IMediaSeeking *seeking;
> + HRESULT hr;
>
> - return E_NOTIMPL;
> + TRACE("iface %p, stop %p\n", iface, stop);
> +
> + EnterCriticalSection(&filter->cs);
> +
> + seeking = get_seeking(filter->seekable_stream);
> +
> + if (!seeking)
> + {
> + LeaveCriticalSection(&filter->cs);
> + return E_NOTIMPL;
> + }
> +
> + hr = IMediaSeeking_GetStopPosition(seeking, stop);
> +
> + IMediaSeeking_Release(seeking);
> +
> + LeaveCriticalSection(&filter->cs);
> +
> + return hr;
> }
>
> static HRESULT WINAPI filter_seeking_GetCurrentPosition(IMediaSeeking *iface, LONGLONG *current)
> diff --git a/dlls/amstream/tests/amstream.c b/dlls/amstream/tests/amstream.c
> index 50b2d5a761..d9c982948d 100644
> --- a/dlls/amstream/tests/amstream.c
> +++ b/dlls/amstream/tests/amstream.c
> @@ -917,8 +917,11 @@ static HRESULT WINAPI testsource_seeking_GetDuration(IMediaSeeking *iface, LONGL
>
> static HRESULT WINAPI testsource_seeking_GetStopPosition(IMediaSeeking *iface, LONGLONG *stop)
> {
> - ok(0, "Unexpected call.\n");
> - return E_NOTIMPL;
> + struct testfilter *filter = impl_from_IMediaSeeking(iface);
> +
> + *stop = 0x8000000000000000ULL;
> +
> + return S_OK;
> }
>
> static HRESULT WINAPI testsource_seeking_GetCurrentPosition(IMediaSeeking *iface, LONGLONG *current)
> @@ -4814,7 +4817,7 @@ static void test_mediastreamfilter_set_positions(void)
> IAMMediaStream *stream1;
> IAMMediaStream *stream2;
> IAMMediaStream *stream3;
> - LONGLONG stop_position;
> + LONGLONG stop_position, in_stop_position;
> LONGLONG duration;
> IMediaSeeking *seeking;
> IGraphBuilder *graph;
> @@ -4912,6 +4915,12 @@ static void test_mediastreamfilter_set_positions(void)
> ok(duration == 0x8000000000000000ULL, "Got duration %s.\n",
> wine_dbgstr_longlong(duration));
>
> + in_stop_position = 0xdeadbeefdeadbeefULL;
> + hr = IMediaSeeking_GetStopPosition(seeking, &in_stop_position);
> + ok(hr == S_OK, "Got hr %#x.\n", hr);
> + ok(in_stop_position == 0x8000000000000000ULL, "Got stop position %s.\n",
> + wine_dbgstr_longlong(in_stop_position));
> +
Same comments as from #1.
> source2.set_positions_hr = E_FAIL;
> source1.current_position = 0xdeadbeefdeadbeefULL;
> source1.stop_position = 0xdeadbeefdeadbeefULL;
> --
> 2.27.0
>
>
>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 488 bytes
Desc: OpenPGP digital signature
URL: <http://www.winehq.org/pipermail/wine-devel/attachments/20200724/01768124/attachment.sig>
More information about the wine-devel
mailing list