mfmediaengine: Handle shutdown state in Pause().
Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
0f4f7ca937
commit
318aa0f387
|
@ -1820,11 +1820,16 @@ static HRESULT WINAPI media_engine_Play(IMFMediaEngineEx *iface)
|
|||
static HRESULT WINAPI media_engine_Pause(IMFMediaEngineEx *iface)
|
||||
{
|
||||
struct media_engine *engine = impl_from_IMFMediaEngineEx(iface);
|
||||
HRESULT hr = S_OK;
|
||||
|
||||
TRACE("%p.\n", iface);
|
||||
|
||||
EnterCriticalSection(&engine->cs);
|
||||
|
||||
if (engine->flags & FLAGS_ENGINE_SHUT_DOWN)
|
||||
hr = MF_E_SHUTDOWN;
|
||||
else
|
||||
{
|
||||
if (!(engine->flags & FLAGS_ENGINE_PAUSED))
|
||||
{
|
||||
media_engine_set_flag(engine, FLAGS_ENGINE_WAITING | FLAGS_ENGINE_IS_ENDED, FALSE);
|
||||
|
@ -1835,10 +1840,11 @@ static HRESULT WINAPI media_engine_Pause(IMFMediaEngineEx *iface)
|
|||
}
|
||||
|
||||
IMFMediaEngineNotify_EventNotify(engine->callback, MF_MEDIA_ENGINE_EVENT_PURGEQUEUEDEVENTS, 0, 0);
|
||||
}
|
||||
|
||||
LeaveCriticalSection(&engine->cs);
|
||||
|
||||
return S_OK;
|
||||
return hr;
|
||||
}
|
||||
|
||||
static BOOL WINAPI media_engine_GetMuted(IMFMediaEngineEx *iface)
|
||||
|
|
|
@ -417,7 +417,6 @@ todo_wine
|
|||
ok(hr == MF_E_SHUTDOWN, "Unexpected hr %#x.\n", hr);
|
||||
|
||||
hr = IMFMediaEngine_Pause(media_engine);
|
||||
todo_wine
|
||||
ok(hr == MF_E_SHUTDOWN, "Unexpected hr %#x.\n", hr);
|
||||
|
||||
state = IMFMediaEngine_GetMuted(media_engine);
|
||||
|
|
Loading…
Reference in New Issue