2 * Implementation of IEnumMediaTypes Interface
4 * Copyright 2003 Robert Shearman
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #include "quartz_private.h"
23 #include "wine/debug.h"
25 WINE_DEFAULT_DEBUG_CHANNEL(quartz
);
27 BOOL
CompareMediaTypes(const AM_MEDIA_TYPE
* pmt1
, const AM_MEDIA_TYPE
* pmt2
, BOOL bWildcards
)
30 dump_AM_MEDIA_TYPE(pmt1
);
32 dump_AM_MEDIA_TYPE(pmt2
);
33 return (((bWildcards
&& (IsEqualGUID(&pmt1
->majortype
, &GUID_NULL
) || IsEqualGUID(&pmt2
->majortype
, &GUID_NULL
))) || IsEqualGUID(&pmt1
->majortype
, &pmt2
->majortype
)) &&
34 ((bWildcards
&& (IsEqualGUID(&pmt1
->subtype
, &GUID_NULL
) || IsEqualGUID(&pmt2
->subtype
, &GUID_NULL
))) || IsEqualGUID(&pmt1
->subtype
, &pmt2
->subtype
)));
37 void dump_AM_MEDIA_TYPE(const AM_MEDIA_TYPE
* pmt
)
41 TRACE("\t%s\n\t%s\n\t...\n\t%s\n", qzdebugstr_guid(&pmt
->majortype
), qzdebugstr_guid(&pmt
->subtype
), qzdebugstr_guid(&pmt
->formattype
));
44 typedef struct IEnumMediaTypesImpl
46 const IEnumMediaTypesVtbl
* lpVtbl
;
48 ENUMMEDIADETAILS enumMediaDetails
;
50 } IEnumMediaTypesImpl
;
52 static const struct IEnumMediaTypesVtbl IEnumMediaTypesImpl_Vtbl
;
54 HRESULT
IEnumMediaTypesImpl_Construct(const ENUMMEDIADETAILS
* pDetails
, IEnumMediaTypes
** ppEnum
)
57 IEnumMediaTypesImpl
* pEnumMediaTypes
= CoTaskMemAlloc(sizeof(IEnumMediaTypesImpl
));
64 pEnumMediaTypes
->lpVtbl
= &IEnumMediaTypesImpl_Vtbl
;
65 pEnumMediaTypes
->refCount
= 1;
66 pEnumMediaTypes
->uIndex
= 0;
67 pEnumMediaTypes
->enumMediaDetails
.cMediaTypes
= pDetails
->cMediaTypes
;
68 pEnumMediaTypes
->enumMediaDetails
.pMediaTypes
= CoTaskMemAlloc(sizeof(AM_MEDIA_TYPE
) * pDetails
->cMediaTypes
);
69 for (i
= 0; i
< pDetails
->cMediaTypes
; i
++)
70 if (FAILED(CopyMediaType(&pEnumMediaTypes
->enumMediaDetails
.pMediaTypes
[i
], &pDetails
->pMediaTypes
[i
])))
73 CoTaskMemFree(pEnumMediaTypes
->enumMediaDetails
.pMediaTypes
[i
].pbFormat
);
74 CoTaskMemFree(pEnumMediaTypes
->enumMediaDetails
.pMediaTypes
);
77 *ppEnum
= (IEnumMediaTypes
*)(&pEnumMediaTypes
->lpVtbl
);
81 static HRESULT WINAPI
IEnumMediaTypesImpl_QueryInterface(IEnumMediaTypes
* iface
, REFIID riid
, LPVOID
* ppv
)
83 TRACE("(%s, %p)\n", qzdebugstr_guid(riid
), ppv
);
87 if (IsEqualIID(riid
, &IID_IUnknown
))
89 else if (IsEqualIID(riid
, &IID_IEnumMediaTypes
))
94 IUnknown_AddRef((IUnknown
*)(*ppv
));
98 FIXME("No interface for %s!\n", qzdebugstr_guid(riid
));
100 return E_NOINTERFACE
;
103 static ULONG WINAPI
IEnumMediaTypesImpl_AddRef(IEnumMediaTypes
* iface
)
105 IEnumMediaTypesImpl
*This
= (IEnumMediaTypesImpl
*)iface
;
106 ULONG refCount
= InterlockedIncrement(&This
->refCount
);
108 TRACE("(%p)->() AddRef from %d\n", iface
, refCount
- 1);
113 static ULONG WINAPI
IEnumMediaTypesImpl_Release(IEnumMediaTypes
* iface
)
115 IEnumMediaTypesImpl
*This
= (IEnumMediaTypesImpl
*)iface
;
116 ULONG refCount
= InterlockedDecrement(&This
->refCount
);
118 TRACE("(%p)->() Release from %d\n", iface
, refCount
+ 1);
123 for (i
= 0; i
< This
->enumMediaDetails
.cMediaTypes
; i
++)
124 if (This
->enumMediaDetails
.pMediaTypes
[i
].pbFormat
)
125 CoTaskMemFree(This
->enumMediaDetails
.pMediaTypes
[i
].pbFormat
);
126 CoTaskMemFree(This
->enumMediaDetails
.pMediaTypes
);
132 static HRESULT WINAPI
IEnumMediaTypesImpl_Next(IEnumMediaTypes
* iface
, ULONG cMediaTypes
, AM_MEDIA_TYPE
** ppMediaTypes
, ULONG
* pcFetched
)
135 IEnumMediaTypesImpl
*This
= (IEnumMediaTypesImpl
*)iface
;
137 cFetched
= min(This
->enumMediaDetails
.cMediaTypes
, This
->uIndex
+ cMediaTypes
) - This
->uIndex
;
139 TRACE("(%u, %p, %p)\n", cMediaTypes
, ppMediaTypes
, pcFetched
);
140 TRACE("Next uIndex: %u, cFetched: %u\n", This
->uIndex
, cFetched
);
145 for (i
= 0; i
< cFetched
; i
++)
146 if (!(ppMediaTypes
[i
] = CreateMediaType(&This
->enumMediaDetails
.pMediaTypes
[This
->uIndex
+ i
])))
149 DeleteMediaType(ppMediaTypes
[i
]);
151 return E_OUTOFMEMORY
;
155 if ((cMediaTypes
!= 1) || pcFetched
)
156 *pcFetched
= cFetched
;
158 This
->uIndex
+= cFetched
;
160 if (cFetched
!= cMediaTypes
)
165 static HRESULT WINAPI
IEnumMediaTypesImpl_Skip(IEnumMediaTypes
* iface
, ULONG cMediaTypes
)
167 IEnumMediaTypesImpl
*This
= (IEnumMediaTypesImpl
*)iface
;
169 TRACE("(%u)\n", cMediaTypes
);
171 if (This
->uIndex
+ cMediaTypes
< This
->enumMediaDetails
.cMediaTypes
)
173 This
->uIndex
+= cMediaTypes
;
179 static HRESULT WINAPI
IEnumMediaTypesImpl_Reset(IEnumMediaTypes
* iface
)
181 IEnumMediaTypesImpl
*This
= (IEnumMediaTypesImpl
*)iface
;
189 static HRESULT WINAPI
IEnumMediaTypesImpl_Clone(IEnumMediaTypes
* iface
, IEnumMediaTypes
** ppEnum
)
192 IEnumMediaTypesImpl
*This
= (IEnumMediaTypesImpl
*)iface
;
194 TRACE("(%p)\n", ppEnum
);
196 hr
= IEnumMediaTypesImpl_Construct(&This
->enumMediaDetails
, ppEnum
);
199 return IEnumMediaTypes_Skip(*ppEnum
, This
->uIndex
);
202 static const IEnumMediaTypesVtbl IEnumMediaTypesImpl_Vtbl
=
204 IEnumMediaTypesImpl_QueryInterface
,
205 IEnumMediaTypesImpl_AddRef
,
206 IEnumMediaTypesImpl_Release
,
207 IEnumMediaTypesImpl_Next
,
208 IEnumMediaTypesImpl_Skip
,
209 IEnumMediaTypesImpl_Reset
,
210 IEnumMediaTypesImpl_Clone