Jacek Caban : wmvcore: Added IWMWriterAdvanced3 stub implementation.
Alexandre Julliard
julliard at wine.codeweavers.com
Fri Mar 20 08:43:19 CDT 2015
Module: wine
Branch: master
Commit: 63dd502c3a9b476e576ebefd97b532df99c0a8dd
URL: http://source.winehq.org/git/wine.git/?a=commit;h=63dd502c3a9b476e576ebefd97b532df99c0a8dd
Author: Jacek Caban <jacek at codeweavers.com>
Date: Thu Mar 19 16:12:15 2015 +0100
wmvcore: Added IWMWriterAdvanced3 stub implementation.
---
dlls/wmvcore/writer.c | 165 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 165 insertions(+)
diff --git a/dlls/wmvcore/writer.c b/dlls/wmvcore/writer.c
index 3629d4d..f570148 100644
--- a/dlls/wmvcore/writer.c
+++ b/dlls/wmvcore/writer.c
@@ -25,6 +25,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(wmvcore);
typedef struct {
IWMWriter IWMWriter_iface;
+ IWMWriterAdvanced3 IWMWriterAdvanced3_iface;
LONG ref;
} WMWriter;
@@ -43,6 +44,15 @@ static HRESULT WINAPI WMWriter_QueryInterface(IWMWriter *iface, REFIID riid, voi
}else if(IsEqualGUID(&IID_IWMWriter, riid)) {
TRACE("(%p)->(IID_IWMWriter %p)\n", This, ppv);
*ppv = &This->IWMWriter_iface;
+ }else if(IsEqualGUID(&IID_IWMWriterAdvanced, riid)) {
+ TRACE("(%p)->(IID_IWMWriterAdvanced %p)\n", This, ppv);
+ *ppv = &This->IWMWriterAdvanced3_iface;
+ }else if(IsEqualGUID(&IID_IWMWriterAdvanced2, riid)) {
+ TRACE("(%p)->(IID_IWMWriterAdvanced2 %p)\n", This, ppv);
+ *ppv = &This->IWMWriterAdvanced3_iface;
+ }else if(IsEqualGUID(&IID_IWMWriterAdvanced3, riid)) {
+ TRACE("(%p)->(IID_IWMWriterAdvanced3 %p)\n", This, ppv);
+ *ppv = &This->IWMWriterAdvanced3_iface;
}else {
FIXME("Unsupported iface %s\n", debugstr_guid(riid));
*ppv = NULL;
@@ -188,6 +198,160 @@ static const IWMWriterVtbl WMWriterVtbl = {
WMWriter_Flush
};
+static inline WMWriter *impl_from_IWMWriterAdvanced3(IWMWriterAdvanced3 *iface)
+{
+ return CONTAINING_RECORD(iface, WMWriter, IWMWriterAdvanced3_iface);
+}
+
+static HRESULT WINAPI WMWriterAdvanced_QueryInterface(IWMWriterAdvanced3 *iface, REFIID riid, void **ppv)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ return IWMWriter_QueryInterface(&This->IWMWriter_iface, riid, ppv);
+}
+
+static ULONG WINAPI WMWriterAdvanced_AddRef(IWMWriterAdvanced3 *iface)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ return IWMWriter_AddRef(&This->IWMWriter_iface);
+}
+
+static ULONG WINAPI WMWriterAdvanced_Release(IWMWriterAdvanced3 *iface)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ return IWMWriter_Release(&This->IWMWriter_iface);
+}
+
+static HRESULT WINAPI WMWriterAdvanced_GetSinkCount(IWMWriterAdvanced3 *iface, DWORD *sinks)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%p)\n", This, sinks);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_GetSink(IWMWriterAdvanced3 *iface, DWORD sink_num, IWMWriterSink **sink)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u %p)\n", This, sink_num, sink);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_AddSink(IWMWriterAdvanced3 *iface, IWMWriterSink *sink)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%p)\n", This, sink);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_RemoveSink(IWMWriterAdvanced3 *iface, IWMWriterSink *sink)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%p)\n", This, sink);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_WriteStreamSample(IWMWriterAdvanced3 *iface, WORD stream_num,
+ QWORD sample_time, DWORD sample_send_time, QWORD sample_duration, DWORD flags, INSSBuffer *sample)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u %s %u %s %x %p)\n", This, stream_num, wine_dbgstr_longlong(sample_time),
+ sample_send_time, wine_dbgstr_longlong(sample_duration), flags, sample);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_SetLiveSource(IWMWriterAdvanced3 *iface, BOOL is_live_source)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%x)\n", This, is_live_source);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_IsRealTime(IWMWriterAdvanced3 *iface, BOOL *real_time)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%p)\n", This, real_time);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_GetWriterTime(IWMWriterAdvanced3 *iface, QWORD *current_time)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%p)\n", This, current_time);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_GetStatistics(IWMWriterAdvanced3 *iface, WORD stream_num, WM_WRITER_STATISTICS *stats)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u %p)\n", This, stream_num, stats);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_SetSyncTolerance(IWMWriterAdvanced3 *iface, DWORD window)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u)\n", This, window);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced_GetSyncTolerance(IWMWriterAdvanced3 *iface, DWORD *window)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%p)\n", This, window);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced2_GetInputSetting(IWMWriterAdvanced3 *iface, DWORD input_num,
+ const WCHAR *name, WMT_ATTR_DATATYPE *time, BYTE *value, WORD *length)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u %s %p %p %p)\n", This, input_num, debugstr_w(name), time, value, length);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced2_SetInputSetting(IWMWriterAdvanced3 *iface, DWORD input_num,
+ const WCHAR *name, WMT_ATTR_DATATYPE type, const BYTE *value, WORD length)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u %s %d %p %u)\n", This, input_num, debugstr_w(name), type, value, length);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced3_GetStatisticsEx(IWMWriterAdvanced3 *iface, WORD stream_num,
+ WM_WRITER_STATISTICS_EX *stats)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)->(%u %p)\n", This, stream_num, stats);
+ return E_NOTIMPL;
+}
+
+static HRESULT WINAPI WMWriterAdvanced3_SetNonBlocking(IWMWriterAdvanced3 *iface)
+{
+ WMWriter *This = impl_from_IWMWriterAdvanced3(iface);
+ FIXME("(%p)\n", This);
+ return E_NOTIMPL;
+}
+
+static const IWMWriterAdvanced3Vtbl WMWriterAdvanced3Vtbl = {
+ WMWriterAdvanced_QueryInterface,
+ WMWriterAdvanced_AddRef,
+ WMWriterAdvanced_Release,
+ WMWriterAdvanced_GetSinkCount,
+ WMWriterAdvanced_GetSink,
+ WMWriterAdvanced_AddSink,
+ WMWriterAdvanced_RemoveSink,
+ WMWriterAdvanced_WriteStreamSample,
+ WMWriterAdvanced_SetLiveSource,
+ WMWriterAdvanced_IsRealTime,
+ WMWriterAdvanced_GetWriterTime,
+ WMWriterAdvanced_GetStatistics,
+ WMWriterAdvanced_SetSyncTolerance,
+ WMWriterAdvanced_GetSyncTolerance,
+ WMWriterAdvanced2_GetInputSetting,
+ WMWriterAdvanced2_SetInputSetting,
+ WMWriterAdvanced3_GetStatisticsEx,
+ WMWriterAdvanced3_SetNonBlocking
+};
+
HRESULT WINAPI WMCreateWriter(IUnknown *reserved, IWMWriter **writer)
{
WMWriter *ret;
@@ -199,6 +363,7 @@ HRESULT WINAPI WMCreateWriter(IUnknown *reserved, IWMWriter **writer)
return E_OUTOFMEMORY;
ret->IWMWriter_iface.lpVtbl = &WMWriterVtbl;
+ ret->IWMWriterAdvanced3_iface.lpVtbl = &WMWriterAdvanced3Vtbl;
ret->ref = 1;
*writer = &ret->IWMWriter_iface;
More information about the wine-cvs
mailing list