[PATCH v5 3/6] qedit: Implement IMediaDet::put_Filter().

Zebediah Figura z.figura12 at gmail.com
Thu Apr 23 14:45:42 CDT 2020


From: Gabriel Ivăncescu <gabrielopcode at gmail.com>

Signed-off-by: Gabriel Ivăncescu <gabrielopcode at gmail.com>
Signed-off-by: Zebediah Figura <z.figura12 at gmail.com>
---
v5: Use clearer variable names; remove a superfluous comment.

This supersedes <https://source.winehq.org/patches/data/183891>.

 dlls/qedit/mediadet.c | 47 +++++++++++++++++++++++++++++++++++++++----
 1 file changed, 43 insertions(+), 4 deletions(-)

diff --git a/dlls/qedit/mediadet.c b/dlls/qedit/mediadet.c
index 49d9bc36c0d..22df05647eb 100644
--- a/dlls/qedit/mediadet.c
+++ b/dlls/qedit/mediadet.c
@@ -309,11 +309,50 @@ static HRESULT WINAPI MediaDet_get_Filter(IMediaDet *iface, IUnknown **filter)
     return S_OK;
 }
 
-static HRESULT WINAPI MediaDet_put_Filter(IMediaDet* iface, IUnknown *newVal)
+static HRESULT WINAPI MediaDet_put_Filter(IMediaDet *iface, IUnknown *unk)
 {
-    MediaDetImpl *This = impl_from_IMediaDet(iface);
-    FIXME("(%p)->(%p): not implemented!\n", This, newVal);
-    return E_NOTIMPL;
+    MediaDetImpl *detector = impl_from_IMediaDet(iface);
+    IGraphBuilder *graph;
+    IBaseFilter *filter;
+    HRESULT hr;
+
+    TRACE("detector %p, unk %p.\n", detector, unk);
+
+    if (!unk)
+        return E_POINTER;
+
+    if (FAILED(hr = IUnknown_QueryInterface(unk, &IID_IBaseFilter, (void **)&filter)))
+    {
+        WARN("Object does not expose IBaseFilter.\n");
+        return hr;
+    }
+
+    if (detector->graph)
+        MD_cleanup(detector);
+
+    if (FAILED(hr = CoCreateInstance(&CLSID_FilterGraph, NULL,
+            CLSCTX_INPROC_SERVER, &IID_IGraphBuilder, (void **)&graph)))
+    {
+        IBaseFilter_Release(filter);
+        return hr;
+    }
+
+    if (FAILED(hr = IGraphBuilder_AddFilter(graph, filter, L"Source")))
+    {
+        IGraphBuilder_Release(graph);
+        IBaseFilter_Release(filter);
+        return hr;
+    }
+
+    detector->graph = graph;
+    detector->source = filter;
+    if (FAILED(find_splitter(detector)))
+    {
+        detector->splitter = detector->source;
+        IBaseFilter_AddRef(detector->splitter);
+    }
+
+    return IMediaDet_put_CurrentStream(&detector->IMediaDet_iface, 0);
 }
 
 static HRESULT WINAPI MediaDet_get_OutputStreams(IMediaDet* iface, LONG *pVal)
-- 
2.26.0




More information about the wine-devel mailing list