Commit 22848359 authored by Michael Stefaniuc's avatar Michael Stefaniuc Committed by Alexandre Julliard

qcap: Basic COM cleanup for IPin iface of VfwCapture.

parent e3c6777e
...@@ -670,9 +670,14 @@ static const IKsPropertySetVtbl KSP_VTable = ...@@ -670,9 +670,14 @@ static const IKsPropertySetVtbl KSP_VTable =
KSP_QuerySupported KSP_QuerySupported
}; };
static HRESULT WINAPI VfwPin_GetMediaType(BasePin *iface, int iPosition, AM_MEDIA_TYPE *pmt) static inline VfwPinImpl *impl_from_BasePin(BasePin *pin)
{ {
VfwPinImpl *This = (VfwPinImpl *)iface; return CONTAINING_RECORD(pin, VfwPinImpl, pin.pin);
}
static HRESULT WINAPI VfwPin_GetMediaType(BasePin *pin, int iPosition, AM_MEDIA_TYPE *pmt)
{
VfwPinImpl *This = impl_from_BasePin(pin);
AM_MEDIA_TYPE *vfw_pmt; AM_MEDIA_TYPE *vfw_pmt;
HRESULT hr; HRESULT hr;
...@@ -748,9 +753,14 @@ VfwPin_Construct( IBaseFilter * pBaseFilter, LPCRITICAL_SECTION pCritSec, ...@@ -748,9 +753,14 @@ VfwPin_Construct( IBaseFilter * pBaseFilter, LPCRITICAL_SECTION pCritSec,
return hr; return hr;
} }
static inline VfwPinImpl *impl_from_IPin(IPin *iface)
{
return CONTAINING_RECORD(iface, VfwPinImpl, pin.pin.IPin_iface);
}
static HRESULT WINAPI VfwPin_QueryInterface(IPin * iface, REFIID riid, LPVOID * ppv) static HRESULT WINAPI VfwPin_QueryInterface(IPin * iface, REFIID riid, LPVOID * ppv)
{ {
VfwPinImpl *This = (VfwPinImpl *)iface; VfwPinImpl *This = impl_from_IPin(iface);
TRACE("%s %p\n", debugstr_guid(riid), ppv); TRACE("%s %p\n", debugstr_guid(riid), ppv);
...@@ -775,7 +785,7 @@ static HRESULT WINAPI VfwPin_QueryInterface(IPin * iface, REFIID riid, LPVOID * ...@@ -775,7 +785,7 @@ static HRESULT WINAPI VfwPin_QueryInterface(IPin * iface, REFIID riid, LPVOID *
static ULONG WINAPI static ULONG WINAPI
VfwPin_Release(IPin * iface) VfwPin_Release(IPin * iface)
{ {
VfwPinImpl *This = (VfwPinImpl *)iface; VfwPinImpl *This = impl_from_IPin(iface);
ULONG refCount = InterlockedDecrement(&This->pin.pin.refCount); ULONG refCount = InterlockedDecrement(&This->pin.pin.refCount);
TRACE("() -> new refcount: %u\n", refCount); TRACE("() -> new refcount: %u\n", refCount);
...@@ -791,10 +801,10 @@ VfwPin_Release(IPin * iface) ...@@ -791,10 +801,10 @@ VfwPin_Release(IPin * iface)
static HRESULT WINAPI static HRESULT WINAPI
VfwPin_EnumMediaTypes(IPin * iface, IEnumMediaTypes ** ppEnum) VfwPin_EnumMediaTypes(IPin * iface, IEnumMediaTypes ** ppEnum)
{ {
VfwPinImpl *This = impl_from_IPin(iface);
AM_MEDIA_TYPE *pmt; AM_MEDIA_TYPE *pmt;
HRESULT hr; HRESULT hr;
VfwPinImpl *This = (VfwPinImpl *)iface;
hr = qcap_driver_get_format(This->parent->driver_info, &pmt); hr = qcap_driver_get_format(This->parent->driver_info, &pmt);
if (SUCCEEDED(hr)) { if (SUCCEEDED(hr)) {
hr = BasePinImpl_EnumMediaTypes(iface, ppEnum); hr = BasePinImpl_EnumMediaTypes(iface, ppEnum);
......
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