[PATCH 4/5] mfplat: Move sample implementation together with buffers.

Nikolay Sivov nsivov at codeweavers.com
Tue Mar 5 01:49:41 CST 2019


Signed-off-by: Nikolay Sivov <nsivov at codeweavers.com>
---
 dlls/mfplat/buffer.c | 409 +++++++++++++++++++++++++++++++++++++++
 dlls/mfplat/main.c   | 444 -------------------------------------------
 2 files changed, 409 insertions(+), 444 deletions(-)

diff --git a/dlls/mfplat/buffer.c b/dlls/mfplat/buffer.c
index e206b356dc..f60c015c6c 100644
--- a/dlls/mfplat/buffer.c
+++ b/dlls/mfplat/buffer.c
@@ -35,11 +35,22 @@ struct memory_buffer
     DWORD current_length;
 };
 
+struct sample
+{
+    struct attributes attributes;
+    IMFSample IMFSample_iface;
+};
+
 static inline struct memory_buffer *impl_from_IMFMediaBuffer(IMFMediaBuffer *iface)
 {
     return CONTAINING_RECORD(iface, struct memory_buffer, IMFMediaBuffer_iface);
 }
 
+static inline struct sample *impl_from_IMFSample(IMFSample *iface)
+{
+    return CONTAINING_RECORD(iface, struct sample, IMFSample_iface);
+}
+
 static HRESULT WINAPI memory_buffer_QueryInterface(IMFMediaBuffer *iface, REFIID riid, void **out)
 {
     struct memory_buffer *buffer = impl_from_IMFMediaBuffer(iface);
@@ -214,3 +225,401 @@ HRESULT WINAPI MFCreateAlignedMemoryBuffer(DWORD max_length, DWORD alignment, IM
 
     return create_memory_buffer(max_length, alignment, buffer);
 }
+
+static HRESULT WINAPI sample_QueryInterface(IMFSample *iface, REFIID riid, void **out)
+{
+    TRACE("%p, %s, %p.\n", iface, debugstr_guid(riid), out);
+
+    if (IsEqualIID(riid, &IID_IMFSample) ||
+            IsEqualIID(riid, &IID_IMFAttributes) ||
+            IsEqualIID(riid, &IID_IUnknown))
+    {
+        *out = iface;
+        IMFSample_AddRef(iface);
+        return S_OK;
+    }
+
+    WARN("Unsupported %s.\n", debugstr_guid(riid));
+    *out = NULL;
+    return E_NOINTERFACE;
+}
+
+static ULONG WINAPI sample_AddRef(IMFSample *iface)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    ULONG refcount = InterlockedIncrement(&sample->attributes.ref);
+
+    TRACE("%p, refcount %u.\n", iface, refcount);
+
+    return refcount;
+}
+
+static ULONG WINAPI sample_Release(IMFSample *iface)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    ULONG refcount = InterlockedDecrement(&sample->attributes.ref);
+
+    TRACE("%p, refcount %u.\n", iface, refcount);
+
+    if (!refcount)
+    {
+        heap_free(sample);
+    }
+
+    return refcount;
+}
+
+static HRESULT WINAPI sample_GetItem(IMFSample *iface, REFGUID key, PROPVARIANT *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetItem(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_GetItemType(IMFSample *iface, REFGUID key, MF_ATTRIBUTE_TYPE *type)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetItemType(&sample->attributes.IMFAttributes_iface, key, type);
+}
+
+static HRESULT WINAPI sample_CompareItem(IMFSample *iface, REFGUID key, REFPROPVARIANT value, BOOL *result)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_CompareItem(&sample->attributes.IMFAttributes_iface, key, value, result);
+}
+
+static HRESULT WINAPI sample_Compare(IMFSample *iface, IMFAttributes *theirs, MF_ATTRIBUTES_MATCH_TYPE type,
+        BOOL *result)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_Compare(&sample->attributes.IMFAttributes_iface, theirs, type, result);
+}
+
+static HRESULT WINAPI sample_GetUINT32(IMFSample *iface, REFGUID key, UINT32 *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetUINT32(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_GetUINT64(IMFSample *iface, REFGUID key, UINT64 *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetUINT64(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_GetDouble(IMFSample *iface, REFGUID key, double *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetDouble(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_GetGUID(IMFSample *iface, REFGUID key, GUID *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetGUID(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_GetStringLength(IMFSample *iface, REFGUID key, UINT32 *length)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetStringLength(&sample->attributes.IMFAttributes_iface, key, length);
+}
+
+static HRESULT WINAPI sample_GetString(IMFSample *iface, REFGUID key, WCHAR *value, UINT32 size, UINT32 *length)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetString(&sample->attributes.IMFAttributes_iface, key, value, size, length);
+}
+
+static HRESULT WINAPI sample_GetAllocatedString(IMFSample *iface, REFGUID key, WCHAR **value, UINT32 *length)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetAllocatedString(&sample->attributes.IMFAttributes_iface, key, value, length);
+}
+
+static HRESULT WINAPI sample_GetBlobSize(IMFSample *iface, REFGUID key, UINT32 *size)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetBlobSize(&sample->attributes.IMFAttributes_iface, key, size);
+}
+
+static HRESULT WINAPI sample_GetBlob(IMFSample *iface, REFGUID key, UINT8 *buf, UINT32 bufsize, UINT32 *blobsize)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetBlob(&sample->attributes.IMFAttributes_iface, key, buf, bufsize, blobsize);
+}
+
+static HRESULT WINAPI sample_GetAllocatedBlob(IMFSample *iface, REFGUID key, UINT8 **buf, UINT32 *size)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetAllocatedBlob(&sample->attributes.IMFAttributes_iface, key, buf, size);
+}
+
+static HRESULT WINAPI sample_GetUnknown(IMFSample *iface, REFGUID key, REFIID riid, void **ppv)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetUnknown(&sample->attributes.IMFAttributes_iface, key, riid, ppv);
+}
+
+static HRESULT WINAPI sample_SetItem(IMFSample *iface, REFGUID key, REFPROPVARIANT value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetItem(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_DeleteItem(IMFSample *iface, REFGUID key)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_DeleteItem(&sample->attributes.IMFAttributes_iface, key);
+}
+
+static HRESULT WINAPI sample_DeleteAllItems(IMFSample *iface)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_DeleteAllItems(&sample->attributes.IMFAttributes_iface);
+}
+
+static HRESULT WINAPI sample_SetUINT32(IMFSample *iface, REFGUID key, UINT32 value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetUINT32(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_SetUINT64(IMFSample *iface, REFGUID key, UINT64 value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetUINT64(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_SetDouble(IMFSample *iface, REFGUID key, double value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetDouble(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_SetGUID(IMFSample *iface, REFGUID key, REFGUID value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetGUID(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_SetString(IMFSample *iface, REFGUID key, const WCHAR *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetString(&sample->attributes.IMFAttributes_iface, key, value);
+}
+
+static HRESULT WINAPI sample_SetBlob(IMFSample *iface, REFGUID key, const UINT8 *buf, UINT32 size)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetBlob(&sample->attributes.IMFAttributes_iface, key, buf, size);
+}
+
+static HRESULT WINAPI sample_SetUnknown(IMFSample *iface, REFGUID key, IUnknown *unknown)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_SetUnknown(&sample->attributes.IMFAttributes_iface, key, unknown);
+}
+
+static HRESULT WINAPI sample_LockStore(IMFSample *iface)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_LockStore(&sample->attributes.IMFAttributes_iface);
+}
+
+static HRESULT WINAPI sample_UnlockStore(IMFSample *iface)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_UnlockStore(&sample->attributes.IMFAttributes_iface);
+}
+
+static HRESULT WINAPI sample_GetCount(IMFSample *iface, UINT32 *items)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetCount(&sample->attributes.IMFAttributes_iface, items);
+}
+
+static HRESULT WINAPI sample_GetItemByIndex(IMFSample *iface, UINT32 index, GUID *key, PROPVARIANT *value)
+{
+    struct sample *sample = impl_from_IMFSample(iface);
+    return IMFAttributes_GetItemByIndex(&sample->attributes.IMFAttributes_iface, index, key, value);
+}
+
+static HRESULT WINAPI sample_CopyAllItems(IMFSample *iface, IMFAttributes *dest)
+{
+    FIXME("%p, %p.\n", iface, dest);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_GetSampleFlags(IMFSample *iface, DWORD *flags)
+{
+    FIXME("%p, %p.\n", iface, flags);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_SetSampleFlags(IMFSample *iface, DWORD flags)
+{
+    FIXME("%p, %#x.\n", iface, flags);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_GetSampleTime(IMFSample *iface, LONGLONG *sampletime)
+{
+    FIXME("%p, %p.\n", iface, sampletime);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_SetSampleTime(IMFSample *iface, LONGLONG sampletime)
+{
+    FIXME("%p, %s.\n", iface, wine_dbgstr_longlong(sampletime));
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_GetSampleDuration(IMFSample *iface, LONGLONG *duration)
+{
+    FIXME("%p, %p.\n", iface, duration);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_SetSampleDuration(IMFSample *iface, LONGLONG duration)
+{
+    FIXME("%p, %s.\n", iface, wine_dbgstr_longlong(duration));
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_GetBufferCount(IMFSample *iface, DWORD *count)
+{
+    FIXME("%p, %p.\n", iface, count);
+
+    if (*count)
+        *count = 0;
+
+    return S_OK;
+}
+
+static HRESULT WINAPI sample_GetBufferByIndex(IMFSample *iface, DWORD index, IMFMediaBuffer **buffer)
+{
+    FIXME("%p, %u, %p.\n", iface, index, buffer);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_ConvertToContiguousBuffer(IMFSample *iface, IMFMediaBuffer **buffer)
+{
+    FIXME("%p, %p.\n", iface, buffer);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_AddBuffer(IMFSample *iface, IMFMediaBuffer *buffer)
+{
+    FIXME("%p, %p.\n", iface, buffer);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_RemoveBufferByIndex(IMFSample *iface, DWORD index)
+{
+    FIXME("%p, %u.\n", iface, index);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_RemoveAllBuffers(IMFSample *iface)
+{
+    FIXME("%p.\n", iface);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_GetTotalLength(IMFSample *iface, DWORD *length)
+{
+    FIXME("%p, %p.\n", iface, length);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI sample_CopyToBuffer(IMFSample *iface, IMFMediaBuffer *buffer)
+{
+    FIXME("%p, %p.\n", iface, buffer);
+
+    return E_NOTIMPL;
+}
+
+static const IMFSampleVtbl samplevtbl =
+{
+    sample_QueryInterface,
+    sample_AddRef,
+    sample_Release,
+    sample_GetItem,
+    sample_GetItemType,
+    sample_CompareItem,
+    sample_Compare,
+    sample_GetUINT32,
+    sample_GetUINT64,
+    sample_GetDouble,
+    sample_GetGUID,
+    sample_GetStringLength,
+    sample_GetString,
+    sample_GetAllocatedString,
+    sample_GetBlobSize,
+    sample_GetBlob,
+    sample_GetAllocatedBlob,
+    sample_GetUnknown,
+    sample_SetItem,
+    sample_DeleteItem,
+    sample_DeleteAllItems,
+    sample_SetUINT32,
+    sample_SetUINT64,
+    sample_SetDouble,
+    sample_SetGUID,
+    sample_SetString,
+    sample_SetBlob,
+    sample_SetUnknown,
+    sample_LockStore,
+    sample_UnlockStore,
+    sample_GetCount,
+    sample_GetItemByIndex,
+    sample_CopyAllItems,
+    sample_GetSampleFlags,
+    sample_SetSampleFlags,
+    sample_GetSampleTime,
+    sample_SetSampleTime,
+    sample_GetSampleDuration,
+    sample_SetSampleDuration,
+    sample_GetBufferCount,
+    sample_GetBufferByIndex,
+    sample_ConvertToContiguousBuffer,
+    sample_AddBuffer,
+    sample_RemoveBufferByIndex,
+    sample_RemoveAllBuffers,
+    sample_GetTotalLength,
+    sample_CopyToBuffer,
+};
+
+/***********************************************************************
+ *      MFCreateSample (mfplat.@)
+ */
+HRESULT WINAPI MFCreateSample(IMFSample **sample)
+{
+    struct sample *object;
+
+    TRACE("%p.\n", sample);
+
+    object = heap_alloc(sizeof(*object));
+    if (!object)
+        return E_OUTOFMEMORY;
+
+    init_attribute_object(&object->attributes, 0);
+    object->IMFSample_iface.lpVtbl = &samplevtbl;
+
+    *sample = &object->IMFSample_iface;
+
+    return S_OK;
+}
diff --git a/dlls/mfplat/main.c b/dlls/mfplat/main.c
index 57943cf115..787c40c6b6 100644
--- a/dlls/mfplat/main.c
+++ b/dlls/mfplat/main.c
@@ -2798,450 +2798,6 @@ HRESULT WINAPI MFCreateEventQueue(IMFMediaEventQueue **queue)
     return S_OK;
 }
 
-
-typedef struct _mfsample
-{
-    mfattributes attributes;
-    IMFSample IMFSample_iface;
-} mfsample;
-
-static inline mfsample *impl_from_IMFSample(IMFSample *iface)
-{
-    return CONTAINING_RECORD(iface, mfsample, IMFSample_iface);
-}
-
-static HRESULT WINAPI mfsample_QueryInterface(IMFSample *iface, REFIID riid, void **out)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    TRACE("(%p)->(%s %p)\n", This, debugstr_guid(riid), out);
-
-    if(IsEqualGUID(riid, &IID_IUnknown)      ||
-       IsEqualGUID(riid, &IID_IMFAttributes) ||
-       IsEqualGUID(riid, &IID_IMFSample))
-    {
-        *out = &This->IMFSample_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 mfsample_AddRef(IMFSample *iface)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    ULONG ref = InterlockedIncrement(&This->attributes.ref);
-
-    TRACE("(%p) ref=%u\n", This, ref);
-
-    return ref;
-}
-
-static ULONG WINAPI mfsample_Release(IMFSample *iface)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    ULONG ref = InterlockedDecrement(&This->attributes.ref);
-
-    TRACE("(%p) ref=%u\n", This, ref);
-
-    if (!ref)
-    {
-        heap_free(This);
-    }
-
-    return ref;
-}
-
-static HRESULT WINAPI mfsample_GetItem(IMFSample *iface, REFGUID key, PROPVARIANT *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetItem(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_GetItemType(IMFSample *iface, REFGUID key, MF_ATTRIBUTE_TYPE *type)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetItemType(&This->attributes.IMFAttributes_iface, key, type);
-}
-
-static HRESULT WINAPI mfsample_CompareItem(IMFSample *iface, REFGUID key, REFPROPVARIANT value, BOOL *result)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_CompareItem(&This->attributes.IMFAttributes_iface, key, value, result);
-}
-
-static HRESULT WINAPI mfsample_Compare(IMFSample *iface, IMFAttributes *theirs, MF_ATTRIBUTES_MATCH_TYPE type,
-                BOOL *result)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_Compare(&This->attributes.IMFAttributes_iface, theirs, type, result);
-}
-
-static HRESULT WINAPI mfsample_GetUINT32(IMFSample *iface, REFGUID key, UINT32 *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetUINT32(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_GetUINT64(IMFSample *iface, REFGUID key, UINT64 *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetUINT64(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_GetDouble(IMFSample *iface, REFGUID key, double *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetDouble(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_GetGUID(IMFSample *iface, REFGUID key, GUID *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetGUID(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_GetStringLength(IMFSample *iface, REFGUID key, UINT32 *length)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetStringLength(&This->attributes.IMFAttributes_iface, key, length);
-}
-
-static HRESULT WINAPI mfsample_GetString(IMFSample *iface, REFGUID key, WCHAR *value,
-                UINT32 size, UINT32 *length)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetString(&This->attributes.IMFAttributes_iface, key, value, size, length);
-}
-
-static HRESULT WINAPI mfsample_GetAllocatedString(IMFSample *iface, REFGUID key,
-                                      WCHAR **value, UINT32 *length)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetAllocatedString(&This->attributes.IMFAttributes_iface, key, value, length);
-}
-
-static HRESULT WINAPI mfsample_GetBlobSize(IMFSample *iface, REFGUID key, UINT32 *size)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetBlobSize(&This->attributes.IMFAttributes_iface, key, size);
-}
-
-static HRESULT WINAPI mfsample_GetBlob(IMFSample *iface, REFGUID key, UINT8 *buf,
-                UINT32 bufsize, UINT32 *blobsize)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetBlob(&This->attributes.IMFAttributes_iface, key, buf, bufsize, blobsize);
-}
-
-static HRESULT WINAPI mfsample_GetAllocatedBlob(IMFSample *iface, REFGUID key, UINT8 **buf, UINT32 *size)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetAllocatedBlob(&This->attributes.IMFAttributes_iface, key, buf, size);
-}
-
-static HRESULT WINAPI mfsample_GetUnknown(IMFSample *iface, REFGUID key, REFIID riid, void **ppv)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetUnknown(&This->attributes.IMFAttributes_iface, key, riid, ppv);
-}
-
-static HRESULT WINAPI mfsample_SetItem(IMFSample *iface, REFGUID key, REFPROPVARIANT value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetItem(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_DeleteItem(IMFSample *iface, REFGUID key)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_DeleteItem(&This->attributes.IMFAttributes_iface, key);
-}
-
-static HRESULT WINAPI mfsample_DeleteAllItems(IMFSample *iface)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_DeleteAllItems(&This->attributes.IMFAttributes_iface);
-}
-
-static HRESULT WINAPI mfsample_SetUINT32(IMFSample *iface, REFGUID key, UINT32 value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetUINT32(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_SetUINT64(IMFSample *iface, REFGUID key, UINT64 value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetUINT64(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_SetDouble(IMFSample *iface, REFGUID key, double value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetDouble(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_SetGUID(IMFSample *iface, REFGUID key, REFGUID value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetGUID(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_SetString(IMFSample *iface, REFGUID key, const WCHAR *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetString(&This->attributes.IMFAttributes_iface, key, value);
-}
-
-static HRESULT WINAPI mfsample_SetBlob(IMFSample *iface, REFGUID key, const UINT8 *buf, UINT32 size)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetBlob(&This->attributes.IMFAttributes_iface, key, buf, size);
-}
-
-static HRESULT WINAPI mfsample_SetUnknown(IMFSample *iface, REFGUID key, IUnknown *unknown)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_SetUnknown(&This->attributes.IMFAttributes_iface, key, unknown);
-}
-
-static HRESULT WINAPI mfsample_LockStore(IMFSample *iface)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_LockStore(&This->attributes.IMFAttributes_iface);
-}
-
-static HRESULT WINAPI mfsample_UnlockStore(IMFSample *iface)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_UnlockStore(&This->attributes.IMFAttributes_iface);
-}
-
-static HRESULT WINAPI mfsample_GetCount(IMFSample *iface, UINT32 *items)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetCount(&This->attributes.IMFAttributes_iface, items);
-}
-
-static HRESULT WINAPI mfsample_GetItemByIndex(IMFSample *iface, UINT32 index, GUID *key, PROPVARIANT *value)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-    return IMFAttributes_GetItemByIndex(&This->attributes.IMFAttributes_iface, index, key, value);
-}
-
-static HRESULT WINAPI mfsample_CopyAllItems(IMFSample *iface, IMFAttributes *dest)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, dest);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_GetSampleFlags(IMFSample *iface, DWORD *flags)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, flags);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_SetSampleFlags(IMFSample *iface, DWORD flags)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %x\n", This, flags);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_GetSampleTime(IMFSample *iface, LONGLONG *sampletime)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, sampletime);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_SetSampleTime(IMFSample *iface, LONGLONG sampletime)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %s\n", This, wine_dbgstr_longlong(sampletime));
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_GetSampleDuration(IMFSample *iface, LONGLONG *duration)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, duration);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_SetSampleDuration(IMFSample *iface, LONGLONG duration)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %s\n", This, wine_dbgstr_longlong(duration));
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_GetBufferCount(IMFSample *iface, DWORD *count)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, count);
-
-    if(*count)
-        *count = 0;
-
-    return S_OK;
-}
-
-static HRESULT WINAPI mfsample_GetBufferByIndex(IMFSample *iface, DWORD index, IMFMediaBuffer **buffer)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %u, %p\n", This, index, buffer);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_ConvertToContiguousBuffer(IMFSample *iface, IMFMediaBuffer **buffer)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, buffer);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_AddBuffer(IMFSample *iface, IMFMediaBuffer *buffer)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, buffer);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_RemoveBufferByIndex(IMFSample *iface, DWORD index)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %u\n", This, index);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_RemoveAllBuffers(IMFSample *iface)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p\n", This);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_GetTotalLength(IMFSample *iface, DWORD *length)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, length);
-
-    return E_NOTIMPL;
-}
-
-static HRESULT WINAPI mfsample_CopyToBuffer(IMFSample *iface, IMFMediaBuffer *buffer)
-{
-    mfsample *This = impl_from_IMFSample(iface);
-
-    FIXME("%p, %p\n", This, buffer);
-
-    return E_NOTIMPL;
-}
-
-static const IMFSampleVtbl mfsample_vtbl =
-{
-    mfsample_QueryInterface,
-    mfsample_AddRef,
-    mfsample_Release,
-    mfsample_GetItem,
-    mfsample_GetItemType,
-    mfsample_CompareItem,
-    mfsample_Compare,
-    mfsample_GetUINT32,
-    mfsample_GetUINT64,
-    mfsample_GetDouble,
-    mfsample_GetGUID,
-    mfsample_GetStringLength,
-    mfsample_GetString,
-    mfsample_GetAllocatedString,
-    mfsample_GetBlobSize,
-    mfsample_GetBlob,
-    mfsample_GetAllocatedBlob,
-    mfsample_GetUnknown,
-    mfsample_SetItem,
-    mfsample_DeleteItem,
-    mfsample_DeleteAllItems,
-    mfsample_SetUINT32,
-    mfsample_SetUINT64,
-    mfsample_SetDouble,
-    mfsample_SetGUID,
-    mfsample_SetString,
-    mfsample_SetBlob,
-    mfsample_SetUnknown,
-    mfsample_LockStore,
-    mfsample_UnlockStore,
-    mfsample_GetCount,
-    mfsample_GetItemByIndex,
-    mfsample_CopyAllItems,
-    mfsample_GetSampleFlags,
-    mfsample_SetSampleFlags,
-    mfsample_GetSampleTime,
-    mfsample_SetSampleTime,
-    mfsample_GetSampleDuration,
-    mfsample_SetSampleDuration,
-    mfsample_GetBufferCount,
-    mfsample_GetBufferByIndex,
-    mfsample_ConvertToContiguousBuffer,
-    mfsample_AddBuffer,
-    mfsample_RemoveBufferByIndex,
-    mfsample_RemoveAllBuffers,
-    mfsample_GetTotalLength,
-    mfsample_CopyToBuffer
-};
-
-HRESULT WINAPI MFCreateSample(IMFSample **sample)
-{
-    mfsample *object;
-
-    TRACE("%p\n", sample);
-
-    object = heap_alloc(sizeof(*object));
-    if(!object)
-        return E_OUTOFMEMORY;
-
-    init_attribute_object(&object->attributes, 0);
-    object->IMFSample_iface.lpVtbl = &mfsample_vtbl;
-    *sample = &object->IMFSample_iface;
-
-    return S_OK;
-}
-
 struct collection
 {
     IMFCollection IMFCollection_iface;
-- 
2.20.1




More information about the wine-devel mailing list