mirror of
https://github.com/reactos/wine.git
synced 2024-11-27 13:40:50 +00:00
mf: Added MFCreateTopology and stub IMFTopology implementation.
Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
9e3ebed4a4
commit
8323871f55
3
configure
vendored
3
configure
vendored
@ -18237,7 +18237,8 @@ wine_fn_config_dll mcicda enable_mcicda
|
|||||||
wine_fn_config_dll mciqtz32 enable_mciqtz32
|
wine_fn_config_dll mciqtz32 enable_mciqtz32
|
||||||
wine_fn_config_dll mciseq enable_mciseq
|
wine_fn_config_dll mciseq enable_mciseq
|
||||||
wine_fn_config_dll mciwave enable_mciwave
|
wine_fn_config_dll mciwave enable_mciwave
|
||||||
wine_fn_config_dll mf enable_mf
|
wine_fn_config_dll mf enable_mf implib
|
||||||
|
wine_fn_config_test dlls/mf/tests mf_test
|
||||||
wine_fn_config_dll mf3216 enable_mf3216
|
wine_fn_config_dll mf3216 enable_mf3216
|
||||||
wine_fn_config_dll mfplat enable_mfplat implib
|
wine_fn_config_dll mfplat enable_mfplat implib
|
||||||
wine_fn_config_test dlls/mfplat/tests mfplat_test
|
wine_fn_config_test dlls/mfplat/tests mfplat_test
|
||||||
|
@ -3181,7 +3181,8 @@ WINE_CONFIG_DLL(mcicda)
|
|||||||
WINE_CONFIG_DLL(mciqtz32)
|
WINE_CONFIG_DLL(mciqtz32)
|
||||||
WINE_CONFIG_DLL(mciseq)
|
WINE_CONFIG_DLL(mciseq)
|
||||||
WINE_CONFIG_DLL(mciwave)
|
WINE_CONFIG_DLL(mciwave)
|
||||||
WINE_CONFIG_DLL(mf)
|
WINE_CONFIG_DLL(mf,,[implib])
|
||||||
|
WINE_CONFIG_TEST(dlls/mf/tests)
|
||||||
WINE_CONFIG_DLL(mf3216)
|
WINE_CONFIG_DLL(mf3216)
|
||||||
WINE_CONFIG_DLL(mfplat,,[implib])
|
WINE_CONFIG_DLL(mfplat,,[implib])
|
||||||
WINE_CONFIG_TEST(dlls/mfplat/tests)
|
WINE_CONFIG_TEST(dlls/mfplat/tests)
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
MODULE = mf.dll
|
MODULE = mf.dll
|
||||||
|
IMPORTLIB = mf
|
||||||
|
|
||||||
C_SRCS = \
|
C_SRCS = \
|
||||||
main.c
|
main.c \
|
||||||
|
topology.c
|
||||||
|
@ -60,7 +60,7 @@
|
|||||||
@ stdcall MFCreateSourceResolver(ptr) mfplat.MFCreateSourceResolver
|
@ stdcall MFCreateSourceResolver(ptr) mfplat.MFCreateSourceResolver
|
||||||
@ stub MFCreateStandardQualityManager
|
@ stub MFCreateStandardQualityManager
|
||||||
@ stub MFCreateTopoLoader
|
@ stub MFCreateTopoLoader
|
||||||
@ stub MFCreateTopology
|
@ stdcall MFCreateTopology(ptr)
|
||||||
@ stub MFCreateTopologyNode
|
@ stub MFCreateTopologyNode
|
||||||
@ stub MFCreateTranscodeProfile
|
@ stub MFCreateTranscodeProfile
|
||||||
@ stub MFCreateTranscodeSinkActivate
|
@ stub MFCreateTranscodeSinkActivate
|
||||||
|
5
dlls/mf/tests/Makefile.in
Normal file
5
dlls/mf/tests/Makefile.in
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
TESTDLL = mf.dll
|
||||||
|
IMPORTS = mf
|
||||||
|
|
||||||
|
C_SRCS = \
|
||||||
|
mf.c
|
49
dlls/mf/tests/mf.c
Normal file
49
dlls/mf/tests/mf.c
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Unit tests for mf.dll.
|
||||||
|
*
|
||||||
|
* Copyright 2017 Nikolay Sivov
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#define COBJMACROS
|
||||||
|
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
|
||||||
|
#include "mfidl.h"
|
||||||
|
|
||||||
|
#include "wine/test.h"
|
||||||
|
|
||||||
|
static void test_topology(void)
|
||||||
|
{
|
||||||
|
IMFTopology *topology;
|
||||||
|
HRESULT hr;
|
||||||
|
|
||||||
|
hr = MFCreateTopology(NULL);
|
||||||
|
ok(hr == E_POINTER, "got %#x\n", hr);
|
||||||
|
|
||||||
|
hr = MFCreateTopology(&topology);
|
||||||
|
ok(hr == S_OK, "got %#x\n", hr);
|
||||||
|
IMFTopology_Release(topology);
|
||||||
|
}
|
||||||
|
|
||||||
|
START_TEST(mf)
|
||||||
|
{
|
||||||
|
test_topology();
|
||||||
|
}
|
523
dlls/mf/topology.c
Normal file
523
dlls/mf/topology.c
Normal file
@ -0,0 +1,523 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2017 Nikolay Sivov
|
||||||
|
*
|
||||||
|
* This library is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU Lesser General Public
|
||||||
|
* License as published by the Free Software Foundation; either
|
||||||
|
* version 2.1 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#define COBJMACROS
|
||||||
|
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
#include "initguid.h"
|
||||||
|
#include "mfidl.h"
|
||||||
|
|
||||||
|
#include "wine/debug.h"
|
||||||
|
|
||||||
|
WINE_DEFAULT_DEBUG_CHANNEL(mfplat);
|
||||||
|
|
||||||
|
typedef struct mftopology
|
||||||
|
{
|
||||||
|
IMFTopology IMFTopology_iface;
|
||||||
|
LONG ref;
|
||||||
|
} mftopology;
|
||||||
|
|
||||||
|
static inline mftopology *impl_from_IMFTopology(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
return CONTAINING_RECORD(iface, mftopology, IMFTopology_iface);
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_QueryInterface(IMFTopology *iface, REFIID riid, void **out)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
TRACE("(%p)->(%s %p)\n", This, debugstr_guid(riid), out);
|
||||||
|
|
||||||
|
if (IsEqualIID(riid, &IID_IMFTopology) ||
|
||||||
|
IsEqualIID(riid, &IID_IMFAttributes) ||
|
||||||
|
IsEqualIID(riid, &IID_IUnknown))
|
||||||
|
{
|
||||||
|
*out = &This->IMFTopology_iface;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FIXME("(%s, %p)\n", debugstr_guid(riid), out);
|
||||||
|
*out = NULL;
|
||||||
|
return E_NOINTERFACE;
|
||||||
|
}
|
||||||
|
|
||||||
|
IUnknown_AddRef((IUnknown*)*out);
|
||||||
|
return S_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ULONG WINAPI mftopology_AddRef(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
ULONG ref = InterlockedIncrement(&This->ref);
|
||||||
|
|
||||||
|
TRACE("(%p) ref=%u\n", This, ref);
|
||||||
|
|
||||||
|
return ref;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ULONG WINAPI mftopology_Release(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
ULONG ref = InterlockedDecrement(&This->ref);
|
||||||
|
|
||||||
|
TRACE("(%p) ref=%u\n", This, ref);
|
||||||
|
|
||||||
|
if (!ref)
|
||||||
|
{
|
||||||
|
HeapFree(GetProcessHeap(), 0, This);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ref;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetItem(IMFTopology *iface, REFGUID key, PROPVARIANT *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetItemType(IMFTopology *iface, REFGUID key, MF_ATTRIBUTE_TYPE *type)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), type);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_CompareItem(IMFTopology *iface, REFGUID key, REFPROPVARIANT value, BOOL *result)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p, %p)\n", This, debugstr_guid(key), value, result);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_Compare(IMFTopology *iface, IMFAttributes *theirs, MF_ATTRIBUTES_MATCH_TYPE type,
|
||||||
|
BOOL *result)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p, %d, %p)\n", This, theirs, type, result);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetUINT32(IMFTopology *iface, REFGUID key, UINT32 *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetUINT64(IMFTopology *iface, REFGUID key, UINT64 *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetDouble(IMFTopology *iface, REFGUID key, double *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetGUID(IMFTopology *iface, REFGUID key, GUID *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetStringLength(IMFTopology *iface, REFGUID key, UINT32 *length)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), length);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetString(IMFTopology *iface, REFGUID key, WCHAR *value,
|
||||||
|
UINT32 size, UINT32 *length)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p, %d, %p)\n", This, debugstr_guid(key), value, size, length);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetAllocatedString(IMFTopology *iface, REFGUID key,
|
||||||
|
WCHAR **value, UINT32 *length)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p, %p)\n", This, debugstr_guid(key), value, length);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetBlobSize(IMFTopology *iface, REFGUID key, UINT32 *size)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), size);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetBlob(IMFTopology *iface, REFGUID key, UINT8 *buf,
|
||||||
|
UINT32 bufsize, UINT32 *blobsize)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p, %d, %p)\n", This, debugstr_guid(key), buf, bufsize, blobsize);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetAllocatedBlob(IMFTopology *iface, REFGUID key, UINT8 **buf, UINT32 *size)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p, %p)\n", This, debugstr_guid(key), buf, size);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetUnknown(IMFTopology *iface, REFGUID key, REFIID riid, void **ppv)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %s, %p)\n", This, debugstr_guid(key), debugstr_guid(riid), ppv);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetItem(IMFTopology *iface, REFGUID key, REFPROPVARIANT Value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), Value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_DeleteItem(IMFTopology *iface, REFGUID key)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s)\n", This, debugstr_guid(key));
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_DeleteAllItems(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)\n", This);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetUINT32(IMFTopology *iface, REFGUID key, UINT32 value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %d)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetUINT64(IMFTopology *iface, REFGUID key, UINT64 value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %s)\n", This, debugstr_guid(key), wine_dbgstr_longlong(value));
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetDouble(IMFTopology *iface, REFGUID key, double value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %f)\n", This, debugstr_guid(key), value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetGUID(IMFTopology *iface, REFGUID key, REFGUID value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %s)\n", This, debugstr_guid(key), debugstr_guid(value));
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetString(IMFTopology *iface, REFGUID key, const WCHAR *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %s)\n", This, debugstr_guid(key), debugstr_w(value));
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetBlob(IMFTopology *iface, REFGUID key, const UINT8 *buf, UINT32 size)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p, %d)\n", This, debugstr_guid(key), buf, size);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_SetUnknown(IMFTopology *iface, REFGUID key, IUnknown *unknown)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%s, %p)\n", This, debugstr_guid(key), unknown);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_LockStore(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)\n", This);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_UnlockStore(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)\n", This);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetCount(IMFTopology *iface, UINT32 *count)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, count);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetItemByIndex(IMFTopology *iface, UINT32 index, GUID *key, PROPVARIANT *value)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%u, %p, %p)\n", This, index, key, value);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_CopyAllItems(IMFTopology *iface, IMFAttributes *dest)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, dest);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetTopologyID(IMFTopology *iface, TOPOID *id)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, id);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_AddNode(IMFTopology *iface, IMFTopologyNode *node)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, node);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_RemoveNode(IMFTopology *iface, IMFTopologyNode *node)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, node);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetNodeCount(IMFTopology *iface, WORD *count)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, count);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetNode(IMFTopology *iface, WORD index, IMFTopologyNode **node)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%u, %p)\n", This, index, node);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_Clear(IMFTopology *iface)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)\n", This);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_CloneFrom(IMFTopology *iface, IMFTopology *topology)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, topology);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetNodeByID(IMFTopology *iface, TOPOID id, IMFTopologyNode **node)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, node);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetSourceNodeCollection(IMFTopology *iface, IMFCollection **collection)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, collection);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI mftopology_GetOutputNodeCollection(IMFTopology *iface, IMFCollection **collection)
|
||||||
|
{
|
||||||
|
mftopology *This = impl_from_IMFTopology(iface);
|
||||||
|
|
||||||
|
FIXME("(%p)->(%p)\n", This, collection);
|
||||||
|
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const IMFTopologyVtbl mftopologyvtbl =
|
||||||
|
{
|
||||||
|
mftopology_QueryInterface,
|
||||||
|
mftopology_AddRef,
|
||||||
|
mftopology_Release,
|
||||||
|
mftopology_GetItem,
|
||||||
|
mftopology_GetItemType,
|
||||||
|
mftopology_CompareItem,
|
||||||
|
mftopology_Compare,
|
||||||
|
mftopology_GetUINT32,
|
||||||
|
mftopology_GetUINT64,
|
||||||
|
mftopology_GetDouble,
|
||||||
|
mftopology_GetGUID,
|
||||||
|
mftopology_GetStringLength,
|
||||||
|
mftopology_GetString,
|
||||||
|
mftopology_GetAllocatedString,
|
||||||
|
mftopology_GetBlobSize,
|
||||||
|
mftopology_GetBlob,
|
||||||
|
mftopology_GetAllocatedBlob,
|
||||||
|
mftopology_GetUnknown,
|
||||||
|
mftopology_SetItem,
|
||||||
|
mftopology_DeleteItem,
|
||||||
|
mftopology_DeleteAllItems,
|
||||||
|
mftopology_SetUINT32,
|
||||||
|
mftopology_SetUINT64,
|
||||||
|
mftopology_SetDouble,
|
||||||
|
mftopology_SetGUID,
|
||||||
|
mftopology_SetString,
|
||||||
|
mftopology_SetBlob,
|
||||||
|
mftopology_SetUnknown,
|
||||||
|
mftopology_LockStore,
|
||||||
|
mftopology_UnlockStore,
|
||||||
|
mftopology_GetCount,
|
||||||
|
mftopology_GetItemByIndex,
|
||||||
|
mftopology_CopyAllItems,
|
||||||
|
mftopology_GetTopologyID,
|
||||||
|
mftopology_AddNode,
|
||||||
|
mftopology_RemoveNode,
|
||||||
|
mftopology_GetNodeCount,
|
||||||
|
mftopology_GetNode,
|
||||||
|
mftopology_Clear,
|
||||||
|
mftopology_CloneFrom,
|
||||||
|
mftopology_GetNodeByID,
|
||||||
|
mftopology_GetSourceNodeCollection,
|
||||||
|
mftopology_GetOutputNodeCollection,
|
||||||
|
};
|
||||||
|
|
||||||
|
/***********************************************************************
|
||||||
|
* MFCreateTopology (mf.@)
|
||||||
|
*/
|
||||||
|
HRESULT WINAPI MFCreateTopology(IMFTopology **topology)
|
||||||
|
{
|
||||||
|
mftopology *object;
|
||||||
|
|
||||||
|
if (!topology)
|
||||||
|
return E_POINTER;
|
||||||
|
|
||||||
|
object = HeapAlloc(GetProcessHeap(), 0, sizeof(*object));
|
||||||
|
if (!object)
|
||||||
|
return E_OUTOFMEMORY;
|
||||||
|
|
||||||
|
object->IMFTopology_iface.lpVtbl = &mftopologyvtbl;
|
||||||
|
object->ref = 1;
|
||||||
|
|
||||||
|
*topology = &object->IMFTopology_iface;
|
||||||
|
|
||||||
|
return S_OK;
|
||||||
|
}
|
@ -164,3 +164,4 @@ interface IMFSourceResolver : IUnknown
|
|||||||
}
|
}
|
||||||
|
|
||||||
cpp_quote("HRESULT WINAPI MFCreateSourceResolver(IMFSourceResolver **resolver);")
|
cpp_quote("HRESULT WINAPI MFCreateSourceResolver(IMFSourceResolver **resolver);")
|
||||||
|
cpp_quote("HRESULT WINAPI MFCreateTopology(IMFTopology **topology);")
|
||||||
|
Loading…
Reference in New Issue
Block a user