Commit ea16925d authored by Alessandro Pignotti's avatar Alessandro Pignotti Committed by Alexandre Julliard

quartz: IEnumFiltersImpl needs to access data from IGraphFilterImpl.

parent 371bbf8d
...@@ -28,8 +28,10 @@ typedef struct IEnumFiltersImpl ...@@ -28,8 +28,10 @@ typedef struct IEnumFiltersImpl
{ {
IEnumFilters IEnumFilters_iface; IEnumFilters IEnumFilters_iface;
LONG refCount; LONG refCount;
IBaseFilter ** ppFilters; IGraphVersion * pVersionSource;
int nFilters; LONG Version;
IBaseFilter *** pppFilters;
ULONG * pNumFilters;
ULONG uIndex; ULONG uIndex;
} IEnumFiltersImpl; } IEnumFiltersImpl;
...@@ -40,13 +42,15 @@ static inline IEnumFiltersImpl *impl_from_IEnumFilters(IEnumFilters *iface) ...@@ -40,13 +42,15 @@ static inline IEnumFiltersImpl *impl_from_IEnumFilters(IEnumFilters *iface)
return CONTAINING_RECORD(iface, IEnumFiltersImpl, IEnumFilters_iface); return CONTAINING_RECORD(iface, IEnumFiltersImpl, IEnumFilters_iface);
} }
HRESULT IEnumFiltersImpl_Construct(IBaseFilter ** ppFilters, ULONG nFilters, IEnumFilters ** ppEnum) HRESULT IEnumFiltersImpl_Construct(IGraphVersion * pVersionSource, IBaseFilter *** pppFilters, ULONG * pNumFilters, IEnumFilters ** ppEnum)
{ {
/* Note: The incoming IBaseFilter interfaces are not AddRef'd here as in Windows, /* Note: The incoming IBaseFilter interfaces are not AddRef'd here as in Windows,
* they should have been previously AddRef'd. */ * they should have been previously AddRef'd. */
IEnumFiltersImpl * pEnumFilters = CoTaskMemAlloc(sizeof(IEnumFiltersImpl)); IEnumFiltersImpl * pEnumFilters = CoTaskMemAlloc(sizeof(IEnumFiltersImpl));
HRESULT hr;
LONG currentVersion;
TRACE("(%p, %d, %p)\n", ppFilters, nFilters, ppEnum); TRACE("(%p, %p, %p)\n", pppFilters, pNumFilters, ppEnum);
*ppEnum = NULL; *ppEnum = NULL;
...@@ -58,15 +62,14 @@ HRESULT IEnumFiltersImpl_Construct(IBaseFilter ** ppFilters, ULONG nFilters, IEn ...@@ -58,15 +62,14 @@ HRESULT IEnumFiltersImpl_Construct(IBaseFilter ** ppFilters, ULONG nFilters, IEn
pEnumFilters->IEnumFilters_iface.lpVtbl = &IEnumFiltersImpl_Vtbl; pEnumFilters->IEnumFilters_iface.lpVtbl = &IEnumFiltersImpl_Vtbl;
pEnumFilters->refCount = 1; pEnumFilters->refCount = 1;
pEnumFilters->uIndex = 0; pEnumFilters->uIndex = 0;
pEnumFilters->nFilters = nFilters; pEnumFilters->pNumFilters = pNumFilters;
pEnumFilters->ppFilters = CoTaskMemAlloc(sizeof(IBaseFilter*) * nFilters); pEnumFilters->pppFilters = pppFilters;
if (!pEnumFilters->ppFilters) IGraphVersion_AddRef(pVersionSource);
{ pEnumFilters->pVersionSource = pVersionSource;
CoTaskMemFree(pEnumFilters);
return E_OUTOFMEMORY;
}
memcpy(pEnumFilters->ppFilters, ppFilters, nFilters * sizeof(IBaseFilter*)); /* Store the current version of the graph */
hr = IGraphVersion_QueryVersion(pVersionSource, &currentVersion);
pEnumFilters->Version = (hr==S_OK) ? currentVersion : 0;
*ppEnum = &pEnumFilters->IEnumFilters_iface; *ppEnum = &pEnumFilters->IEnumFilters_iface;
return S_OK; return S_OK;
...@@ -113,8 +116,7 @@ static ULONG WINAPI IEnumFiltersImpl_Release(IEnumFilters * iface) ...@@ -113,8 +116,7 @@ static ULONG WINAPI IEnumFiltersImpl_Release(IEnumFilters * iface)
if (!refCount) if (!refCount)
{ {
CoTaskMemFree(This->ppFilters); IGraphVersion_Release(This->pVersionSource);
CoTaskMemFree(This);
return 0; return 0;
} }
else else
...@@ -125,18 +127,26 @@ static HRESULT WINAPI IEnumFiltersImpl_Next(IEnumFilters * iface, ULONG cFilters ...@@ -125,18 +127,26 @@ static HRESULT WINAPI IEnumFiltersImpl_Next(IEnumFilters * iface, ULONG cFilters
{ {
ULONG cFetched; ULONG cFetched;
ULONG i; ULONG i;
LONG currentVersion;
IEnumFiltersImpl *This = impl_from_IEnumFilters(iface); IEnumFiltersImpl *This = impl_from_IEnumFilters(iface);
HRESULT hr;
cFetched = min(This->nFilters, This->uIndex + cFilters) - This->uIndex; cFetched = min(*This->pNumFilters, This->uIndex + cFilters) - This->uIndex;
TRACE("(%p)->(%u, %p, %p)\n", iface, cFilters, ppFilters, pcFetched); TRACE("(%p)->(%u, %p, %p)\n", iface, cFilters, ppFilters, pcFetched);
/* First of all check if the graph has changed */
hr = IGraphVersion_QueryVersion(This->pVersionSource, &currentVersion);
if (hr==S_OK && This->Version != currentVersion)
return VFW_E_ENUM_OUT_OF_SYNC;
if (!ppFilters) if (!ppFilters)
return E_POINTER; return E_POINTER;
for (i = 0; i < cFetched; i++) for (i = 0; i < cFetched; i++)
{ {
ppFilters[i] = This->ppFilters[This->uIndex + i]; ppFilters[i] = (*This->pppFilters)[This->uIndex + i];
IBaseFilter_AddRef(ppFilters[i]); IBaseFilter_AddRef(ppFilters[i]);
} }
...@@ -156,7 +166,7 @@ static HRESULT WINAPI IEnumFiltersImpl_Skip(IEnumFilters * iface, ULONG cFilters ...@@ -156,7 +166,7 @@ static HRESULT WINAPI IEnumFiltersImpl_Skip(IEnumFilters * iface, ULONG cFilters
TRACE("(%p)->(%u)\n", iface, cFilters); TRACE("(%p)->(%u)\n", iface, cFilters);
if (This->uIndex + cFilters < This->nFilters) if (This->uIndex + cFilters < *This->pNumFilters)
{ {
This->uIndex += cFilters; This->uIndex += cFilters;
return S_OK; return S_OK;
...@@ -167,10 +177,15 @@ static HRESULT WINAPI IEnumFiltersImpl_Skip(IEnumFilters * iface, ULONG cFilters ...@@ -167,10 +177,15 @@ static HRESULT WINAPI IEnumFiltersImpl_Skip(IEnumFilters * iface, ULONG cFilters
static HRESULT WINAPI IEnumFiltersImpl_Reset(IEnumFilters * iface) static HRESULT WINAPI IEnumFiltersImpl_Reset(IEnumFilters * iface)
{ {
IEnumFiltersImpl *This = impl_from_IEnumFilters(iface); IEnumFiltersImpl *This = impl_from_IEnumFilters(iface);
HRESULT hr;
LONG currentVersion;
TRACE("(%p)->()\n", iface); TRACE("(%p)->()\n", iface);
This->uIndex = 0; This->uIndex = 0;
hr = IGraphVersion_QueryVersion(This->pVersionSource, &currentVersion);
if (!hr)
This->Version = currentVersion;
return S_OK; return S_OK;
} }
...@@ -181,7 +196,7 @@ static HRESULT WINAPI IEnumFiltersImpl_Clone(IEnumFilters * iface, IEnumFilters ...@@ -181,7 +196,7 @@ static HRESULT WINAPI IEnumFiltersImpl_Clone(IEnumFilters * iface, IEnumFilters
TRACE("(%p)->(%p)\n", iface, ppEnum); TRACE("(%p)->(%p)\n", iface, ppEnum);
hr = IEnumFiltersImpl_Construct(This->ppFilters, This->nFilters, ppEnum); hr = IEnumFiltersImpl_Construct(This->pVersionSource, This->pppFilters, This->pNumFilters, ppEnum);
if (FAILED(hr)) if (FAILED(hr))
return hr; return hr;
return IEnumFilters_Skip(*ppEnum, This->uIndex); return IEnumFilters_Skip(*ppEnum, This->uIndex);
......
...@@ -162,11 +162,11 @@ typedef struct _IFilterGraphImpl { ...@@ -162,11 +162,11 @@ typedef struct _IFilterGraphImpl {
IGraphConfig IGraphConfig_iface; IGraphConfig IGraphConfig_iface;
IMediaPosition IMediaPosition_iface; IMediaPosition IMediaPosition_iface;
IObjectWithSite IObjectWithSite_iface; IObjectWithSite IObjectWithSite_iface;
IGraphVersion IGraphVersion_iface;
/* IAMGraphStreams */ /* IAMGraphStreams */
/* IAMStats */ /* IAMStats */
/* IFilterChain */ /* IFilterChain */
/* IFilterMapper2 */ /* IFilterMapper2 */
/* IGraphVersion */
/* IQueueCommand */ /* IQueueCommand */
/* IRegisterServiceProvider */ /* IRegisterServiceProvider */
/* IResourceMananger */ /* IResourceMananger */
...@@ -179,7 +179,7 @@ typedef struct _IFilterGraphImpl { ...@@ -179,7 +179,7 @@ typedef struct _IFilterGraphImpl {
IFilterMapper2 * pFilterMapper2; IFilterMapper2 * pFilterMapper2;
IBaseFilter ** ppFiltersInGraph; IBaseFilter ** ppFiltersInGraph;
LPWSTR * pFilterNames; LPWSTR * pFilterNames;
int nFilters; ULONG nFilters;
int filterCapacity; int filterCapacity;
LONG nameIndex; LONG nameIndex;
IReferenceClock *refClock; IReferenceClock *refClock;
...@@ -269,6 +269,9 @@ static HRESULT WINAPI FilterGraphInner_QueryInterface(IUnknown *iface, REFIID ri ...@@ -269,6 +269,9 @@ static HRESULT WINAPI FilterGraphInner_QueryInterface(IUnknown *iface, REFIID ri
} else if (IsEqualGUID(&IID_IFilterMapper3, riid)) { } else if (IsEqualGUID(&IID_IFilterMapper3, riid)) {
*ppvObj = This->pFilterMapper2; *ppvObj = This->pFilterMapper2;
TRACE(" returning IFilterMapper3 interface from aggregated filtermapper (%p)\n", *ppvObj); TRACE(" returning IFilterMapper3 interface from aggregated filtermapper (%p)\n", *ppvObj);
} else if (IsEqualGUID(&IID_IGraphVersion, riid)) {
*ppvObj = &This->IGraphConfig_iface;
TRACE(" returning IGraphConfig interface (%p)\n", *ppvObj);
} else { } else {
*ppvObj = NULL; *ppvObj = NULL;
FIXME("unknown interface %s\n", debugstr_guid(riid)); FIXME("unknown interface %s\n", debugstr_guid(riid));
...@@ -562,7 +565,7 @@ static HRESULT WINAPI FilterGraph2_EnumFilters(IFilterGraph2 *iface, IEnumFilter ...@@ -562,7 +565,7 @@ static HRESULT WINAPI FilterGraph2_EnumFilters(IFilterGraph2 *iface, IEnumFilter
TRACE("(%p/%p)->(%p)\n", This, iface, ppEnum); TRACE("(%p/%p)->(%p)\n", This, iface, ppEnum);
return IEnumFiltersImpl_Construct(This->ppFiltersInGraph, This->nFilters, ppEnum); return IEnumFiltersImpl_Construct(&This->IGraphVersion_iface, &This->ppFiltersInGraph, &This->nFilters, ppEnum);
} }
static HRESULT WINAPI FilterGraph2_FindFilterByName(IFilterGraph2 *iface, LPCWSTR pName, static HRESULT WINAPI FilterGraph2_FindFilterByName(IFilterGraph2 *iface, LPCWSTR pName,
...@@ -5547,6 +5550,49 @@ static const IGraphConfigVtbl IGraphConfig_VTable = ...@@ -5547,6 +5550,49 @@ static const IGraphConfigVtbl IGraphConfig_VTable =
GraphConfig_RemoveFilterEx GraphConfig_RemoveFilterEx
}; };
static inline IFilterGraphImpl *impl_from_IGraphVersion(IGraphVersion *iface)
{
return CONTAINING_RECORD(iface, IFilterGraphImpl, IGraphVersion_iface);
}
static HRESULT WINAPI GraphVersion_QueryInterface(IGraphVersion *iface, REFIID riid, void **ppv)
{
IFilterGraphImpl *This = impl_from_IGraphVersion(iface);
return IUnknown_QueryInterface(This->outer_unk, riid, ppv);
}
static ULONG WINAPI GraphVersion_AddRef(IGraphVersion *iface)
{
IFilterGraphImpl *This = impl_from_IGraphVersion(iface);
return IUnknown_AddRef(This->outer_unk);
}
static ULONG WINAPI GraphVersion_Release(IGraphVersion *iface)
{
IFilterGraphImpl *This = impl_from_IGraphVersion(iface);
return IUnknown_Release(This->outer_unk);
}
static HRESULT WINAPI GraphVersion_QueryVersion(IGraphVersion *iface, LONG *pVersion)
{
IFilterGraphImpl *This = impl_from_IGraphVersion(iface);
FIXME("(%p)->(%p): stub!\n", This, pVersion);
return E_NOTIMPL;
}
static const IGraphVersionVtbl IGraphVersion_VTable =
{
GraphVersion_QueryInterface,
GraphVersion_AddRef,
GraphVersion_Release,
GraphVersion_QueryVersion,
};
static const IUnknownVtbl IInner_VTable = static const IUnknownVtbl IInner_VTable =
{ {
FilterGraphInner_QueryInterface, FilterGraphInner_QueryInterface,
...@@ -5579,6 +5625,7 @@ HRESULT FilterGraph_create(IUnknown *pUnkOuter, LPVOID *ppObj) ...@@ -5579,6 +5625,7 @@ HRESULT FilterGraph_create(IUnknown *pUnkOuter, LPVOID *ppObj)
fimpl->IGraphConfig_iface.lpVtbl = &IGraphConfig_VTable; fimpl->IGraphConfig_iface.lpVtbl = &IGraphConfig_VTable;
fimpl->IMediaPosition_iface.lpVtbl = &IMediaPosition_VTable; fimpl->IMediaPosition_iface.lpVtbl = &IMediaPosition_VTable;
fimpl->IObjectWithSite_iface.lpVtbl = &IObjectWithSite_VTable; fimpl->IObjectWithSite_iface.lpVtbl = &IObjectWithSite_VTable;
fimpl->IGraphVersion_iface.lpVtbl = &IGraphVersion_VTable;
fimpl->ref = 1; fimpl->ref = 1;
fimpl->ppFiltersInGraph = NULL; fimpl->ppFiltersInGraph = NULL;
fimpl->pFilterNames = NULL; fimpl->pFilterNames = NULL;
......
...@@ -59,7 +59,7 @@ HRESULT VMR9Impl_create(IUnknown *pUnkOuter, LPVOID *ppv) DECLSPEC_HIDDEN; ...@@ -59,7 +59,7 @@ HRESULT VMR9Impl_create(IUnknown *pUnkOuter, LPVOID *ppv) DECLSPEC_HIDDEN;
HRESULT EnumMonikerImpl_Create(IMoniker ** ppMoniker, ULONG nMonikerCount, IEnumMoniker ** ppEnum) DECLSPEC_HIDDEN; HRESULT EnumMonikerImpl_Create(IMoniker ** ppMoniker, ULONG nMonikerCount, IEnumMoniker ** ppEnum) DECLSPEC_HIDDEN;
HRESULT IEnumRegFiltersImpl_Construct(REGFILTER * pInRegFilters, const ULONG size, IEnumRegFilters ** ppEnum) DECLSPEC_HIDDEN; HRESULT IEnumRegFiltersImpl_Construct(REGFILTER * pInRegFilters, const ULONG size, IEnumRegFilters ** ppEnum) DECLSPEC_HIDDEN;
HRESULT IEnumFiltersImpl_Construct(IBaseFilter ** ppFilters, ULONG nFilters, IEnumFilters ** ppEnum) DECLSPEC_HIDDEN; HRESULT IEnumFiltersImpl_Construct(IGraphVersion * pVersionSource, IBaseFilter *** pppFilters, ULONG * pNumFilters, IEnumFilters ** ppEnum) DECLSPEC_HIDDEN;
extern const char * qzdebugstr_guid(const GUID * id) DECLSPEC_HIDDEN; extern const char * qzdebugstr_guid(const GUID * id) DECLSPEC_HIDDEN;
extern void video_unregister_windowclass(void) DECLSPEC_HIDDEN; extern void video_unregister_windowclass(void) DECLSPEC_HIDDEN;
......
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