mf: Add a helper to set closed state for the session.
Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
741016dd32
commit
b68a765b95
|
@ -812,6 +812,14 @@ static void session_start(struct media_session *session, const GUID *time_format
|
||||||
LeaveCriticalSection(&session->cs);
|
LeaveCriticalSection(&session->cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void session_set_closed(struct media_session *session, HRESULT status)
|
||||||
|
{
|
||||||
|
session->state = SESSION_STATE_CLOSED;
|
||||||
|
if (SUCCEEDED(status))
|
||||||
|
session_set_caps(session, session->caps & ~(MFSESSIONCAP_START | MFSESSIONCAP_SEEK));
|
||||||
|
IMFMediaEventQueue_QueueEventParamVar(session->event_queue, MESessionClosed, &GUID_NULL, status, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
static void session_pause(struct media_session *session)
|
static void session_pause(struct media_session *session)
|
||||||
{
|
{
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
|
@ -911,11 +919,7 @@ static HRESULT session_finalize_sinks(struct media_session *session)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sinks_finalized)
|
if (sinks_finalized)
|
||||||
{
|
session_set_closed(session, hr);
|
||||||
session->state = SESSION_STATE_CLOSED;
|
|
||||||
session_set_caps(session, session->caps & ~(MFSESSIONCAP_START | MFSESSIONCAP_SEEK));
|
|
||||||
IMFMediaEventQueue_QueueEventParamVar(session->event_queue, MESessionClosed, &GUID_NULL, hr, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
return hr;
|
return hr;
|
||||||
}
|
}
|
||||||
|
@ -945,10 +949,7 @@ static void session_close(struct media_session *session)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FAILED(hr))
|
if (FAILED(hr))
|
||||||
{
|
session_set_closed(session, hr);
|
||||||
session->state = SESSION_STATE_CLOSED;
|
|
||||||
IMFMediaEventQueue_QueueEventParamVar(session->event_queue, MESessionClosed, &GUID_NULL, hr, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
LeaveCriticalSection(&session->cs);
|
LeaveCriticalSection(&session->cs);
|
||||||
}
|
}
|
||||||
|
@ -3018,11 +3019,7 @@ static HRESULT WINAPI session_sink_finalizer_callback_Invoke(IMFAsyncCallback *i
|
||||||
{
|
{
|
||||||
sink->finalized = TRUE;
|
sink->finalized = TRUE;
|
||||||
if (sinks_finalized)
|
if (sinks_finalized)
|
||||||
{
|
session_set_closed(session, hr);
|
||||||
session->state = SESSION_STATE_CLOSED;
|
|
||||||
session_set_caps(session, session->caps & ~(MFSESSIONCAP_START | MFSESSIONCAP_SEEK));
|
|
||||||
IMFMediaEventQueue_QueueEventParamVar(session->event_queue, MESessionClosed, &GUID_NULL, hr, NULL);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
IMFFinalizableMediaSink_Release(fin_sink);
|
IMFFinalizableMediaSink_Release(fin_sink);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue