From: Rémi Bernon rbernon@codeweavers.com
--- dlls/mfmp4srcsnk/Makefile.in | 1 + dlls/mfmp4srcsnk/mfmp4srcsnk.c | 5 + dlls/mfmp4srcsnk/mfmp4srcsnk.idl | 12 +++ dlls/mfsrcsnk/Makefile.in | 1 + dlls/mfsrcsnk/media_sink.c | 99 ++++++++++++++++++++ dlls/mfsrcsnk/mfsrcsnk_private.h | 24 +++++ dlls/mfsrcsnk/wave.c | 21 ----- dlls/winegstreamer/main.c | 6 +- dlls/winegstreamer/winegstreamer_classes.idl | 9 +- 9 files changed, 150 insertions(+), 28 deletions(-) create mode 100644 dlls/mfsrcsnk/media_sink.c
diff --git a/dlls/mfmp4srcsnk/Makefile.in b/dlls/mfmp4srcsnk/Makefile.in index d32a1744bc0..cc91ab58df9 100644 --- a/dlls/mfmp4srcsnk/Makefile.in +++ b/dlls/mfmp4srcsnk/Makefile.in @@ -5,6 +5,7 @@ PARENTSRC = ../mfsrcsnk EXTRADLLFLAGS = -Wb,--prefer-native
SOURCES = \ + media_sink.c \ media_source.c \ mfmp4srcsnk.c \ mfmp4srcsnk.idl \ diff --git a/dlls/mfmp4srcsnk/mfmp4srcsnk.c b/dlls/mfmp4srcsnk/mfmp4srcsnk.c index c6a99334ca7..488d3b9ebd9 100644 --- a/dlls/mfmp4srcsnk/mfmp4srcsnk.c +++ b/dlls/mfmp4srcsnk/mfmp4srcsnk.c @@ -32,6 +32,11 @@ HRESULT WINAPI DllGetClassObject(REFCLSID clsid, REFIID riid, void **out) if (IsEqualGUID(clsid, &CLSID_MPEG4ByteStreamHandlerPlugin)) return IClassFactory_QueryInterface(&mpeg4_byte_stream_plugin_factory, riid, out);
+ if (IsEqualGUID(clsid, &CLSID_MFMP3SinkClassFactory)) + return IClassFactory_QueryInterface(mp3_sink_class_factory, riid, out); + if (IsEqualGUID(clsid, &CLSID_MFMPEG4SinkClassFactory)) + return IClassFactory_QueryInterface(mpeg4_sink_class_factory, riid, out); + FIXME("Unknown clsid %s.\n", debugstr_guid(clsid)); return CLASS_E_CLASSNOTAVAILABLE; } diff --git a/dlls/mfmp4srcsnk/mfmp4srcsnk.idl b/dlls/mfmp4srcsnk/mfmp4srcsnk.idl index 67c6ca58724..e9045b59b93 100644 --- a/dlls/mfmp4srcsnk/mfmp4srcsnk.idl +++ b/dlls/mfmp4srcsnk/mfmp4srcsnk.idl @@ -25,3 +25,15 @@ ] coclass MPEG4ByteStreamHandlerPlugin {}
+[ + threading(both), + uuid(11275a82-5e5a-47fd-a01c-3683c12fb196) +] +coclass MFMP3SinkClassFactory {} + +[ + helpstring("MF MPEG4 Sink Class Factory"), + threading(both), + uuid(a22c4fc7-6e91-4e1d-89e9-53b2667b72ba) +] +coclass MFMPEG4SinkClassFactory {} diff --git a/dlls/mfsrcsnk/Makefile.in b/dlls/mfsrcsnk/Makefile.in index 4b4d209e8c2..d238b43424d 100644 --- a/dlls/mfsrcsnk/Makefile.in +++ b/dlls/mfsrcsnk/Makefile.in @@ -6,6 +6,7 @@ EXTRADLLFLAGS = -Wb,--prefer-native
SOURCES = \ factory.c \ + media_sink.c \ media_source.c \ mfsrcsnk.idl \ mfsrcsnk.rc \ diff --git a/dlls/mfsrcsnk/media_sink.c b/dlls/mfsrcsnk/media_sink.c new file mode 100644 index 00000000000..2927859d937 --- /dev/null +++ b/dlls/mfsrcsnk/media_sink.c @@ -0,0 +1,99 @@ +/* + * Copyright 2023 Ziqing Hui for CodeWeavers + * + * 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 "mfsrcsnk_private.h" + +#include "wine/debug.h" + +WINE_DEFAULT_DEBUG_CHANNEL(mfplat); + +static HRESULT WINAPI mp3_sink_factory_CreateMediaSink(IMFSinkClassFactory *iface, IMFByteStream *bytestream, + IMFMediaType *video_type, IMFMediaType *audio_type, IMFMediaSink **out) +{ + FIXME("stub!\n"); + return E_NOTIMPL; +} + +static const IMFSinkClassFactoryVtbl mp3_sink_factory_vtbl = +{ + sink_class_factory_QueryInterface, + sink_class_factory_AddRef, + sink_class_factory_Release, + mp3_sink_factory_CreateMediaSink, +}; + +static HRESULT WINAPI mp3_sink_class_factory_CreateInstance(IClassFactory *iface, IUnknown *outer, REFIID riid, void **out) +{ + static const GUID CLSID_wg_mp3_sink_factory = {0x1f302877,0xaaab,0x40a3,{0xb9,0xe0,0x9f,0x48,0xda,0xf3,0x5b,0xc8}}; + return CoCreateInstance(&CLSID_wg_mp3_sink_factory, outer, CLSCTX_INPROC_SERVER, riid, out); +} + +static const IClassFactoryVtbl mp3_sink_class_factory_vtbl = +{ + class_factory_QueryInterface, + class_factory_AddRef, + class_factory_Release, + mp3_sink_class_factory_CreateInstance, + class_factory_LockServer, +}; + +struct sink_class_factory mp3_sink_factory = +{ + {&mp3_sink_class_factory_vtbl}, + {&mp3_sink_factory_vtbl}, +}; + +IClassFactory *mp3_sink_class_factory = &mp3_sink_factory.IClassFactory_iface; + +static HRESULT WINAPI mpeg4_sink_factory_CreateMediaSink(IMFSinkClassFactory *iface, IMFByteStream *bytestream, + IMFMediaType *video_type, IMFMediaType *audio_type, IMFMediaSink **out) +{ + FIXME("stub!\n"); + return E_NOTIMPL; +} + +static const IMFSinkClassFactoryVtbl mpeg4_sink_factory_vtbl = +{ + sink_class_factory_QueryInterface, + sink_class_factory_AddRef, + sink_class_factory_Release, + mpeg4_sink_factory_CreateMediaSink, +}; + +static HRESULT WINAPI mpeg4_sink_class_factory_CreateInstance(IClassFactory *iface, IUnknown *outer, REFIID riid, void **out) +{ + static const GUID CLSID_wg_mpeg4_sink_factory = {0x5d5407d9,0xc6ca,0x4770,{0xa7,0xcc,0x27,0xc0,0xcb,0x8a,0x76,0x27}}; + return CoCreateInstance(&CLSID_wg_mpeg4_sink_factory, outer, CLSCTX_INPROC_SERVER, riid, out); +} + +static const IClassFactoryVtbl mpeg4_sink_class_factory_vtbl = +{ + class_factory_QueryInterface, + class_factory_AddRef, + class_factory_Release, + mpeg4_sink_class_factory_CreateInstance, + class_factory_LockServer, +}; + +struct sink_class_factory mpeg4_sink_factory = +{ + {&mpeg4_sink_class_factory_vtbl}, + {&mpeg4_sink_factory_vtbl}, +}; + +IClassFactory *mpeg4_sink_class_factory = &mpeg4_sink_factory.IClassFactory_iface; diff --git a/dlls/mfsrcsnk/mfsrcsnk_private.h b/dlls/mfsrcsnk/mfsrcsnk_private.h index 28caea2a1d2..6d4ef560d5b 100644 --- a/dlls/mfsrcsnk/mfsrcsnk_private.h +++ b/dlls/mfsrcsnk/mfsrcsnk_private.h @@ -23,8 +23,11 @@ #include "mferror.h"
#include "wine/mfinternal.h" +#include "wine/debug.h"
extern IClassFactory *wave_sink_class_factory; +extern IClassFactory *mp3_sink_class_factory; +extern IClassFactory *mpeg4_sink_class_factory;
static inline HRESULT WINAPI class_factory_QueryInterface(IClassFactory *iface, REFIID riid, void **out) { @@ -67,3 +70,24 @@ static inline ULONG WINAPI sink_class_factory_Release(IMFSinkClassFactory *iface { return 1; } + +static inline const char *debugstr_time(LONGLONG time) +{ + ULONGLONG abstime = time >= 0 ? time : -time; + unsigned int i = 0, j = 0; + char buffer[23], rev[23]; + + while (abstime || i <= 8) + { + buffer[i++] = '0' + (abstime % 10); + abstime /= 10; + if (i == 7) buffer[i++] = '.'; + } + if (time < 0) buffer[i++] = '-'; + + while (i--) rev[j++] = buffer[i]; + while (rev[j-1] == '0' && rev[j-2] != '.') --j; + rev[j] = 0; + + return wine_dbg_sprintf("%s", rev); +} diff --git a/dlls/mfsrcsnk/wave.c b/dlls/mfsrcsnk/wave.c index bae70960a72..cc5351ae2a9 100644 --- a/dlls/mfsrcsnk/wave.c +++ b/dlls/mfsrcsnk/wave.c @@ -22,27 +22,6 @@
WINE_DEFAULT_DEBUG_CHANNEL(mfplat);
-static inline const char *debugstr_time(LONGLONG time) -{ - ULONGLONG abstime = time >= 0 ? time : -time; - unsigned int i = 0, j = 0; - char buffer[23], rev[23]; - - while (abstime || i <= 8) - { - buffer[i++] = '0' + (abstime % 10); - abstime /= 10; - if (i == 7) buffer[i++] = '.'; - } - if (time < 0) buffer[i++] = '-'; - - while (i--) rev[j++] = buffer[i]; - while (rev[j-1] == '0' && rev[j-2] != '.') --j; - rev[j] = 0; - - return wine_dbg_sprintf("%s", rev); -} - enum wave_sink_flags { SINK_SHUT_DOWN = 0x1, diff --git a/dlls/winegstreamer/main.c b/dlls/winegstreamer/main.c index 2d144a6f71f..54058f57ba5 100644 --- a/dlls/winegstreamer/main.c +++ b/dlls/winegstreamer/main.c @@ -991,6 +991,8 @@ static struct class_factory mpeg4_sink_class_factory_cf = {{&class_factory_vtbl}
HRESULT WINAPI DllGetClassObject(REFCLSID clsid, REFIID iid, void **out) { + static const GUID CLSID_wg_mp3_sink_factory = {0x1f302877,0xaaab,0x40a3,{0xb9,0xe0,0x9f,0x48,0xda,0xf3,0x5b,0xc8}}; + static const GUID CLSID_wg_mpeg4_sink_factory = {0x5d5407d9,0xc6ca,0x4770,{0xa7,0xcc,0x27,0xc0,0xcb,0x8a,0x76,0x27}}; struct class_factory *factory; HRESULT hr;
@@ -1024,9 +1026,9 @@ HRESULT WINAPI DllGetClassObject(REFCLSID clsid, REFIID iid, void **out) factory = &resampler_cf; else if (IsEqualGUID(clsid, &CLSID_CColorConvertDMO)) factory = &color_convert_cf; - else if (IsEqualGUID(clsid, &CLSID_MFMP3SinkClassFactory)) + else if (IsEqualGUID(clsid, &CLSID_wg_mp3_sink_factory)) factory = &mp3_sink_class_factory_cf; - else if (IsEqualGUID(clsid, &CLSID_MFMPEG4SinkClassFactory)) + else if (IsEqualGUID(clsid, &CLSID_wg_mpeg4_sink_factory)) factory = &mpeg4_sink_class_factory_cf; else { diff --git a/dlls/winegstreamer/winegstreamer_classes.idl b/dlls/winegstreamer/winegstreamer_classes.idl index 41ec2d26123..c960051428d 100644 --- a/dlls/winegstreamer/winegstreamer_classes.idl +++ b/dlls/winegstreamer/winegstreamer_classes.idl @@ -127,13 +127,12 @@ coclass CColorConvertDMO {}
[ threading(both), - uuid(11275a82-5e5a-47fd-a01c-3683c12fb196) + uuid(1f302877-aaab-40a3-b9e0-9f48daf35bc8) ] -coclass MFMP3SinkClassFactory {} +coclass wg_mp3_sink_factory {}
[ - helpstring("MF MPEG4 Sink Class Factory"), threading(both), - uuid(a22c4fc7-6e91-4e1d-89e9-53b2667b72ba) + uuid(5d5407d9-c6ca-4770-a7cc-27c0cb8a7627) ] -coclass MFMPEG4SinkClassFactory {} +coclass wg_mpeg4_sink_factory {}