mirror of
https://github.com/wine-mirror/wine
synced 2024-07-08 20:06:18 +00:00
strmbase: Send EC_COMPLETE in IBaseFilter::Run() for unconnected renderers.
Signed-off-by: Zebediah Figura <zfigura@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
59376f124b
commit
6e11378df2
|
@ -508,7 +508,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Pause(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -520,7 +520,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Stop(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -532,7 +532,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
IMediaControl_Release(control);
|
||||
IMediaEvent_Release(eventsrc);
|
||||
|
|
|
@ -969,7 +969,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Pause(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -981,7 +981,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Stop(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -993,7 +993,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
IMediaControl_Release(control);
|
||||
IMediaEvent_Release(eventsrc);
|
||||
|
|
|
@ -2897,7 +2897,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Pause(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -2909,7 +2909,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Stop(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -2921,7 +2921,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
IMediaControl_Release(control);
|
||||
IMediaEvent_Release(eventsrc);
|
||||
|
|
|
@ -3101,7 +3101,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Pause(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -3113,7 +3113,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Stop(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -3125,7 +3125,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
IMediaControl_Release(control);
|
||||
IMediaEvent_Release(eventsrc);
|
||||
|
|
|
@ -4202,7 +4202,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Pause(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -4214,7 +4214,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
hr = IMediaControl_Stop(control);
|
||||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
@ -4226,7 +4226,7 @@ static void test_unconnected_eos(void)
|
|||
ok(hr == S_OK, "Got hr %#x.\n", hr);
|
||||
|
||||
ret = check_ec_complete(eventsrc, 0);
|
||||
todo_wine ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
ok(ret == 1, "Got %u EC_COMPLETE events.\n", ret);
|
||||
|
||||
IMediaControl_Release(control);
|
||||
IMediaEvent_Release(eventsrc);
|
||||
|
|
|
@ -252,7 +252,7 @@ static HRESULT renderer_start_stream(struct strmbase_filter *iface, REFERENCE_TI
|
|||
if (filter->sink.pin.peer && filter->ops->renderer_start_stream)
|
||||
filter->ops->renderer_start_stream(filter);
|
||||
|
||||
if (filter->eos && graph
|
||||
if ((filter->eos || !filter->sink.pin.peer) && graph
|
||||
&& SUCCEEDED(IFilterGraph_QueryInterface(graph,
|
||||
&IID_IMediaEventSink, (void **)&event_sink)))
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue
Block a user