Commit db143ed0 authored by Zebediah Figura's avatar Zebediah Figura Committed by Alexandre Julliard

qcap: Move the video capture device creation function to the function table.

parent 3657748a
...@@ -40,13 +40,9 @@ HRESULT file_writer_create(IUnknown *outer, IUnknown **out) DECLSPEC_HIDDEN; ...@@ -40,13 +40,9 @@ HRESULT file_writer_create(IUnknown *outer, IUnknown **out) DECLSPEC_HIDDEN;
HRESULT smart_tee_create(IUnknown *outer, IUnknown **out) DECLSPEC_HIDDEN; HRESULT smart_tee_create(IUnknown *outer, IUnknown **out) DECLSPEC_HIDDEN;
HRESULT vfw_capture_create(IUnknown *outer, IUnknown **out) DECLSPEC_HIDDEN; HRESULT vfw_capture_create(IUnknown *outer, IUnknown **out) DECLSPEC_HIDDEN;
struct video_capture_device struct video_capture_funcs
{
const struct video_capture_device_ops *ops;
};
struct video_capture_device_ops
{ {
struct video_capture_device *(*create)(struct strmbase_source *pin, USHORT index);
void (*destroy)(struct video_capture_device *device); void (*destroy)(struct video_capture_device *device);
HRESULT (*check_format)(struct video_capture_device *device, const AM_MEDIA_TYPE *mt); HRESULT (*check_format)(struct video_capture_device *device, const AM_MEDIA_TYPE *mt);
HRESULT (*set_format)(struct video_capture_device *device, const AM_MEDIA_TYPE *mt); HRESULT (*set_format)(struct video_capture_device *device, const AM_MEDIA_TYPE *mt);
...@@ -64,6 +60,6 @@ struct video_capture_device_ops ...@@ -64,6 +60,6 @@ struct video_capture_device_ops
void (*cleanup_stream)(struct video_capture_device *device); void (*cleanup_stream)(struct video_capture_device *device);
}; };
struct video_capture_device *v4l_device_create(struct strmbase_source *pin, USHORT card); extern const struct video_capture_funcs v4l_funcs;
#endif #endif
...@@ -22,6 +22,8 @@ ...@@ -22,6 +22,8 @@
WINE_DEFAULT_DEBUG_CHANNEL(qcap); WINE_DEFAULT_DEBUG_CHANNEL(qcap);
static const struct video_capture_funcs *capture_funcs;
struct vfw_capture struct vfw_capture
{ {
struct strmbase_filter filter; struct strmbase_filter filter;
...@@ -85,8 +87,8 @@ static void vfw_capture_destroy(struct strmbase_filter *iface) ...@@ -85,8 +87,8 @@ static void vfw_capture_destroy(struct strmbase_filter *iface)
if (filter->init) if (filter->init)
{ {
if (filter->filter.state != State_Stopped) if (filter->filter.state != State_Stopped)
filter->device->ops->cleanup_stream(filter->device); capture_funcs->cleanup_stream(filter->device);
filter->device->ops->destroy(filter->device); capture_funcs->destroy(filter->device);
} }
if (filter->source.pin.peer) if (filter->source.pin.peer)
...@@ -123,7 +125,7 @@ static HRESULT vfw_capture_init_stream(struct strmbase_filter *iface) ...@@ -123,7 +125,7 @@ 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);
filter->device->ops->init_stream(filter->device); capture_funcs->init_stream(filter->device);
return S_OK; return S_OK;
} }
...@@ -131,7 +133,7 @@ static HRESULT vfw_capture_start_stream(struct strmbase_filter *iface, REFERENCE ...@@ -131,7 +133,7 @@ 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);
filter->device->ops->start_stream(filter->device); capture_funcs->start_stream(filter->device);
return S_OK; return S_OK;
} }
...@@ -139,7 +141,7 @@ static HRESULT vfw_capture_stop_stream(struct strmbase_filter *iface) ...@@ -139,7 +141,7 @@ 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);
filter->device->ops->stop_stream(filter->device); capture_funcs->stop_stream(filter->device);
return S_OK; return S_OK;
} }
...@@ -147,7 +149,7 @@ static HRESULT vfw_capture_cleanup_stream(struct strmbase_filter *iface) ...@@ -147,7 +149,7 @@ 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);
filter->device->ops->cleanup_stream(filter->device); capture_funcs->cleanup_stream(filter->device);
return S_OK; return S_OK;
} }
...@@ -218,7 +220,7 @@ AMStreamConfig_SetFormat(IAMStreamConfig *iface, AM_MEDIA_TYPE *pmt) ...@@ -218,7 +220,7 @@ AMStreamConfig_SetFormat(IAMStreamConfig *iface, AM_MEDIA_TYPE *pmt)
return VFW_E_INVALIDMEDIATYPE; return VFW_E_INVALIDMEDIATYPE;
} }
hr = This->device->ops->set_format(This->device, pmt); hr = capture_funcs->set_format(This->device, pmt);
if (SUCCEEDED(hr) && This->filter.graph && This->source.pin.peer) if (SUCCEEDED(hr) && This->filter.graph && This->source.pin.peer)
{ {
hr = IFilterGraph_Reconnect(This->filter.graph, &This->source.pin.IPin_iface); hr = IFilterGraph_Reconnect(This->filter.graph, &This->source.pin.IPin_iface);
...@@ -239,7 +241,7 @@ static HRESULT WINAPI AMStreamConfig_GetFormat(IAMStreamConfig *iface, AM_MEDIA_ ...@@ -239,7 +241,7 @@ static HRESULT WINAPI AMStreamConfig_GetFormat(IAMStreamConfig *iface, AM_MEDIA_
if (!(*mt = CoTaskMemAlloc(sizeof(**mt)))) if (!(*mt = CoTaskMemAlloc(sizeof(**mt))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if (SUCCEEDED(hr = filter->device->ops->get_format(filter->device, *mt))) if (SUCCEEDED(hr = capture_funcs->get_format(filter->device, *mt)))
strmbase_dump_media_type(*mt); strmbase_dump_media_type(*mt);
return hr; return hr;
} }
...@@ -254,7 +256,7 @@ static HRESULT WINAPI AMStreamConfig_GetNumberOfCapabilities(IAMStreamConfig *if ...@@ -254,7 +256,7 @@ static HRESULT WINAPI AMStreamConfig_GetNumberOfCapabilities(IAMStreamConfig *if
if (!count || !size) if (!count || !size)
return E_POINTER; return E_POINTER;
*count = filter->device->ops->get_caps_count(filter->device); *count = capture_funcs->get_caps_count(filter->device);
*size = sizeof(VIDEO_STREAM_CONFIG_CAPS); *size = sizeof(VIDEO_STREAM_CONFIG_CAPS);
return S_OK; return S_OK;
...@@ -267,7 +269,7 @@ static HRESULT WINAPI AMStreamConfig_GetStreamCaps(IAMStreamConfig *iface, ...@@ -267,7 +269,7 @@ static HRESULT WINAPI AMStreamConfig_GetStreamCaps(IAMStreamConfig *iface,
TRACE("filter %p, index %d, pmt %p, vscc %p.\n", filter, index, pmt, vscc); TRACE("filter %p, index %d, pmt %p, vscc %p.\n", filter, index, pmt, vscc);
return filter->device->ops->get_caps(filter->device, index, pmt, (VIDEO_STREAM_CONFIG_CAPS *)vscc); return capture_funcs->get_caps(filter->device, index, pmt, (VIDEO_STREAM_CONFIG_CAPS *)vscc);
} }
static const IAMStreamConfigVtbl IAMStreamConfig_VTable = static const IAMStreamConfigVtbl IAMStreamConfig_VTable =
...@@ -307,7 +309,7 @@ static HRESULT WINAPI AMVideoProcAmp_GetRange(IAMVideoProcAmp *iface, LONG prope ...@@ -307,7 +309,7 @@ static HRESULT WINAPI AMVideoProcAmp_GetRange(IAMVideoProcAmp *iface, LONG prope
TRACE("filter %p, property %#x, min %p, max %p, step %p, default_value %p, flags %p.\n", TRACE("filter %p, property %#x, min %p, max %p, step %p, default_value %p, flags %p.\n",
filter, property, min, max, step, default_value, flags); filter, property, min, max, step, default_value, flags);
return filter->device->ops->get_prop_range(filter->device, property, min, return capture_funcs->get_prop_range(filter->device, property, min,
max, step, default_value, flags); max, step, default_value, flags);
} }
...@@ -318,7 +320,7 @@ static HRESULT WINAPI AMVideoProcAmp_Set(IAMVideoProcAmp *iface, LONG property, ...@@ -318,7 +320,7 @@ static HRESULT WINAPI AMVideoProcAmp_Set(IAMVideoProcAmp *iface, LONG property,
TRACE("filter %p, property %#x, value %d, flags %#x.\n", filter, property, value, flags); TRACE("filter %p, property %#x, value %d, flags %#x.\n", filter, property, value, flags);
return filter->device->ops->set_prop(filter->device, property, value, flags); return capture_funcs->set_prop(filter->device, property, value, flags);
} }
static HRESULT WINAPI AMVideoProcAmp_Get(IAMVideoProcAmp *iface, LONG property, static HRESULT WINAPI AMVideoProcAmp_Get(IAMVideoProcAmp *iface, LONG property,
...@@ -328,7 +330,7 @@ static HRESULT WINAPI AMVideoProcAmp_Get(IAMVideoProcAmp *iface, LONG property, ...@@ -328,7 +330,7 @@ static HRESULT WINAPI AMVideoProcAmp_Get(IAMVideoProcAmp *iface, LONG property,
TRACE("filter %p, property %#x, value %p, flags %p.\n", filter, property, value, flags); TRACE("filter %p, property %#x, value %p, flags %p.\n", filter, property, value, flags);
return filter->device->ops->get_prop(filter->device, property, value, flags); return capture_funcs->get_prop(filter->device, property, value, flags);
} }
static const IAMVideoProcAmpVtbl IAMVideoProcAmp_VTable = static const IAMVideoProcAmpVtbl IAMVideoProcAmp_VTable =
...@@ -378,32 +380,24 @@ static HRESULT WINAPI PPB_InitNew(IPersistPropertyBag * iface) ...@@ -378,32 +380,24 @@ static HRESULT WINAPI PPB_InitNew(IPersistPropertyBag * iface)
return E_NOTIMPL; return E_NOTIMPL;
} }
static HRESULT WINAPI static HRESULT WINAPI PPB_Load(IPersistPropertyBag *iface, IPropertyBag *bag, IErrorLog *error_log)
PPB_Load( IPersistPropertyBag * iface, IPropertyBag *pPropBag,
IErrorLog *pErrorLog )
{ {
static const OLECHAR VFWIndex[] = {'V','F','W','I','n','d','e','x',0}; static const OLECHAR VFWIndex[] = {'V','F','W','I','n','d','e','x',0};
struct vfw_capture *This = impl_from_IPersistPropertyBag(iface); struct vfw_capture *filter = impl_from_IPersistPropertyBag(iface);
HRESULT hr; HRESULT hr;
VARIANT var; VARIANT var;
TRACE("%p/%p-> (%p, %p)\n", iface, This, pPropBag, pErrorLog); TRACE("filter %p, bag %p, error_log %p.\n", filter, bag, error_log);
V_VT(&var) = VT_I4; V_VT(&var) = VT_I4;
hr = IPropertyBag_Read(pPropBag, VFWIndex, &var, pErrorLog); if (FAILED(hr = IPropertyBag_Read(bag, VFWIndex, &var, error_log)))
return hr;
if (SUCCEEDED(hr)) if (!(filter->device = capture_funcs->create(&filter->source, V_I4(&var))))
{ return E_FAIL;
if ((This->device = v4l_device_create(&This->source, V_I4(&var))))
{
This->init = TRUE;
hr = S_OK;
}
else
hr = E_FAIL;
}
return hr; filter->init = TRUE;
return S_OK;
} }
static HRESULT WINAPI static HRESULT WINAPI
...@@ -510,14 +504,14 @@ static inline struct vfw_capture *impl_from_strmbase_pin(struct strmbase_pin *pi ...@@ -510,14 +504,14 @@ static inline struct vfw_capture *impl_from_strmbase_pin(struct strmbase_pin *pi
static HRESULT source_query_accept(struct strmbase_pin *pin, const AM_MEDIA_TYPE *mt) static HRESULT source_query_accept(struct strmbase_pin *pin, const AM_MEDIA_TYPE *mt)
{ {
struct vfw_capture *filter = impl_from_strmbase_pin(pin); struct vfw_capture *filter = impl_from_strmbase_pin(pin);
return filter->device->ops->check_format(filter->device, mt); return capture_funcs->check_format(filter->device, mt);
} }
static HRESULT source_get_media_type(struct strmbase_pin *pin, static HRESULT source_get_media_type(struct strmbase_pin *pin,
unsigned int index, AM_MEDIA_TYPE *mt) unsigned int index, AM_MEDIA_TYPE *mt)
{ {
struct vfw_capture *filter = impl_from_strmbase_pin(pin); struct vfw_capture *filter = impl_from_strmbase_pin(pin);
return filter->device->ops->get_media_type(filter->device, index, mt); return capture_funcs->get_media_type(filter->device, index, mt);
} }
static HRESULT source_query_interface(struct strmbase_pin *iface, REFIID iid, void **out) static HRESULT source_query_interface(struct strmbase_pin *iface, REFIID iid, void **out)
...@@ -683,11 +677,22 @@ static const IAMVideoControlVtbl IAMVideoControl_VTable = ...@@ -683,11 +677,22 @@ static const IAMVideoControlVtbl IAMVideoControl_VTable =
video_control_GetFrameRateList video_control_GetFrameRateList
}; };
static BOOL WINAPI load_capture_funcs(INIT_ONCE *once, void *param, void **context)
{
capture_funcs = &v4l_funcs;
return TRUE;
}
static INIT_ONCE init_once = INIT_ONCE_STATIC_INIT;
HRESULT vfw_capture_create(IUnknown *outer, IUnknown **out) HRESULT vfw_capture_create(IUnknown *outer, IUnknown **out)
{ {
static const WCHAR source_name[] = {'O','u','t','p','u','t',0}; static const WCHAR source_name[] = {'O','u','t','p','u','t',0};
struct vfw_capture *object; struct vfw_capture *object;
if (!InitOnceExecuteOnce(&init_once, load_capture_funcs, NULL, NULL))
return E_FAIL;
if (!(object = CoTaskMemAlloc(sizeof(*object)))) if (!(object = CoTaskMemAlloc(sizeof(*object))))
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
......
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