Commit 859809be authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

qcap/vfwcapture: Allow changing state while unconnected.

parent 2552a484
...@@ -296,6 +296,58 @@ static void test_misc_flags(IBaseFilter *filter) ...@@ -296,6 +296,58 @@ static void test_misc_flags(IBaseFilter *filter)
IAMFilterMiscFlags_Release(misc_flags); IAMFilterMiscFlags_Release(misc_flags);
} }
static void test_unconnected_filter_state(IBaseFilter *filter)
{
FILTER_STATE state;
HRESULT hr;
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Stopped, "Got state %u.\n", state);
hr = IBaseFilter_Pause(filter);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Paused, "Got state %u.\n", state);
hr = IBaseFilter_Run(filter, 0);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Running, "Got state %u.\n", state);
hr = IBaseFilter_Pause(filter);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Paused, "Got state %u.\n", state);
hr = IBaseFilter_Stop(filter);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Stopped, "Got state %u.\n", state);
hr = IBaseFilter_Run(filter, 0);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Running, "Got state %u.\n", state);
hr = IBaseFilter_Stop(filter);
ok(hr == S_OK, "Got hr %#x.\n", hr);
hr = IBaseFilter_GetState(filter, 0, &state);
ok(hr == S_OK, "Got hr %#x.\n", hr);
ok(state == State_Stopped, "Got state %u.\n", state);
}
struct testfilter struct testfilter
{ {
struct strmbase_filter filter; struct strmbase_filter filter;
...@@ -615,6 +667,7 @@ START_TEST(videocapture) ...@@ -615,6 +667,7 @@ START_TEST(videocapture)
test_filter_interfaces(filter); test_filter_interfaces(filter);
test_pins(filter); test_pins(filter);
test_misc_flags(filter); test_misc_flags(filter);
test_unconnected_filter_state(filter);
ref = IBaseFilter_Release(filter); ref = IBaseFilter_Release(filter);
ok(!ref, "Got outstanding refcount %d.\n", ref); ok(!ref, "Got outstanding refcount %d.\n", ref);
......
...@@ -199,6 +199,9 @@ static HRESULT vfw_capture_init_stream(struct strmbase_filter *iface) ...@@ -199,6 +199,9 @@ static HRESULT vfw_capture_init_stream(struct strmbase_filter *iface)
struct vfw_capture *filter = impl_from_strmbase_filter(iface); struct vfw_capture *filter = impl_from_strmbase_filter(iface);
HRESULT hr; HRESULT hr;
if (!filter->source.pin.peer)
return S_OK;
if (FAILED(hr = IMemAllocator_Commit(filter->source.pAllocator))) if (FAILED(hr = IMemAllocator_Commit(filter->source.pAllocator)))
ERR("Failed to commit allocator, hr %#x.\n", hr); ERR("Failed to commit allocator, hr %#x.\n", hr);
...@@ -215,6 +218,9 @@ static HRESULT vfw_capture_start_stream(struct strmbase_filter *iface, REFERENCE ...@@ -215,6 +218,9 @@ static HRESULT vfw_capture_start_stream(struct strmbase_filter *iface, REFERENCE
{ {
struct vfw_capture *filter = impl_from_strmbase_filter(iface); struct vfw_capture *filter = impl_from_strmbase_filter(iface);
if (!filter->source.pin.peer)
return S_OK;
EnterCriticalSection(&filter->state_cs); EnterCriticalSection(&filter->state_cs);
filter->state = State_Running; filter->state = State_Running;
LeaveCriticalSection(&filter->state_cs); LeaveCriticalSection(&filter->state_cs);
...@@ -226,6 +232,9 @@ static HRESULT vfw_capture_stop_stream(struct strmbase_filter *iface) ...@@ -226,6 +232,9 @@ static HRESULT vfw_capture_stop_stream(struct strmbase_filter *iface)
{ {
struct vfw_capture *filter = impl_from_strmbase_filter(iface); struct vfw_capture *filter = impl_from_strmbase_filter(iface);
if (!filter->source.pin.peer)
return S_OK;
EnterCriticalSection(&filter->state_cs); EnterCriticalSection(&filter->state_cs);
filter->state = State_Paused; filter->state = State_Paused;
LeaveCriticalSection(&filter->state_cs); LeaveCriticalSection(&filter->state_cs);
...@@ -237,6 +246,9 @@ static HRESULT vfw_capture_cleanup_stream(struct strmbase_filter *iface) ...@@ -237,6 +246,9 @@ static HRESULT vfw_capture_cleanup_stream(struct strmbase_filter *iface)
struct vfw_capture *filter = impl_from_strmbase_filter(iface); struct vfw_capture *filter = impl_from_strmbase_filter(iface);
HRESULT hr; HRESULT hr;
if (!filter->source.pin.peer)
return S_OK;
EnterCriticalSection(&filter->state_cs); EnterCriticalSection(&filter->state_cs);
filter->state = State_Stopped; filter->state = State_Stopped;
LeaveCriticalSection(&filter->state_cs); LeaveCriticalSection(&filter->state_cs);
...@@ -255,7 +267,11 @@ static HRESULT vfw_capture_cleanup_stream(struct strmbase_filter *iface) ...@@ -255,7 +267,11 @@ static HRESULT vfw_capture_cleanup_stream(struct strmbase_filter *iface)
static HRESULT vfw_capture_wait_state(struct strmbase_filter *iface, DWORD timeout) static HRESULT vfw_capture_wait_state(struct strmbase_filter *iface, DWORD timeout)
{ {
return iface->state == State_Paused ? VFW_S_CANT_CUE : S_OK; struct vfw_capture *filter = impl_from_strmbase_filter(iface);
if (filter->source.pin.peer && filter->filter.state == State_Paused)
return VFW_S_CANT_CUE;
return S_OK;
} }
static const struct strmbase_filter_ops filter_ops = static const struct strmbase_filter_ops filter_ops =
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment