Andrew Eikum : xaudio2_8: Don' t use IXAudio27 interface to call Initialize.

Alexandre Julliard julliard at wine.codeweavers.com
Tue Jan 19 10:50:28 CST 2016


Module: wine
Branch: master
Commit: fb954b7b9f2ddc477464a22e39426a0c27ab397c
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=fb954b7b9f2ddc477464a22e39426a0c27ab397c

Author: Andrew Eikum <aeikum at codeweavers.com>
Date:   Mon Jan 18 13:15:54 2016 -0600

xaudio2_8: Don't use IXAudio27 interface to call Initialize.

Signed-off-by: Andrew Eikum <aeikum at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/xaudio2_7/compat.c         |  6 +++---
 dlls/xaudio2_7/xaudio_dll.c     | 21 ++++++++++-----------
 dlls/xaudio2_7/xaudio_private.h |  1 +
 3 files changed, 14 insertions(+), 14 deletions(-)

diff --git a/dlls/xaudio2_7/compat.c b/dlls/xaudio2_7/compat.c
index ffe6531..88dd850 100644
--- a/dlls/xaudio2_7/compat.c
+++ b/dlls/xaudio2_7/compat.c
@@ -468,7 +468,7 @@ static HRESULT WINAPI XA27_Initialize(IXAudio27 *iface, UINT32 flags,
 {
     IXAudio2Impl *This = impl_from_IXAudio27(iface);
     TRACE("(%p)->(0x%x, 0x%x)\n", This, flags, processor);
-    return S_OK;
+    return xaudio2_initialize(This, flags, processor);
 }
 
 static HRESULT WINAPI XA27_RegisterForCallbacks(IXAudio27 *iface,
@@ -1305,7 +1305,7 @@ static HRESULT WINAPI XA22_Initialize(IXAudio22 *iface, UINT32 flags,
 {
     IXAudio2Impl *This = impl_from_IXAudio22(iface);
     TRACE("(%p)->(0x%x, 0x%x)\n", This, flags, processor);
-    return S_OK;
+    return xaudio2_initialize(This, flags, processor);
 }
 
 static HRESULT WINAPI XA22_RegisterForCallbacks(IXAudio22 *iface,
@@ -2163,7 +2163,7 @@ static HRESULT WINAPI XA20_Initialize(IXAudio20 *iface, UINT32 flags,
 {
     IXAudio2Impl *This = impl_from_IXAudio20(iface);
     TRACE("(%p)->(0x%x, 0x%x)\n", This, flags, processor);
-    return S_OK;
+    return xaudio2_initialize(This, flags, processor);
 }
 
 static HRESULT WINAPI XA20_RegisterForCallbacks(IXAudio20 *iface,
diff --git a/dlls/xaudio2_7/xaudio_dll.c b/dlls/xaudio2_7/xaudio_dll.c
index efa6279..86c8cbf 100644
--- a/dlls/xaudio2_7/xaudio_dll.c
+++ b/dlls/xaudio2_7/xaudio_dll.c
@@ -2046,14 +2046,22 @@ HRESULT WINAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, void **ppv)
     return IClassFactory_QueryInterface(factory, riid, ppv);
 }
 
+HRESULT xaudio2_initialize(IXAudio2Impl *This, UINT32 flags, XAUDIO2_PROCESSOR proc)
+{
+    if(flags)
+        FIXME("Unimplemented flags: 0x%x\n", flags);
+    return S_OK;
+}
+
 #if XAUDIO2_VER >= 8
 HRESULT WINAPI XAudio2Create(IXAudio2 **ppxa2, UINT32 flags, XAUDIO2_PROCESSOR proc)
 {
     HRESULT hr;
     IXAudio2 *xa2;
-    IXAudio27 *xa27;
     IClassFactory *cf;
 
+    TRACE("%p 0x%x 0x%x\n", ppxa2, flags, proc);
+
     cf = make_xaudio2_factory();
 
     hr = IClassFactory_CreateInstance(cf, NULL, &IID_IXAudio2, (void**)&xa2);
@@ -2061,21 +2069,12 @@ HRESULT WINAPI XAudio2Create(IXAudio2 **ppxa2, UINT32 flags, XAUDIO2_PROCESSOR p
     if(FAILED(hr))
         return hr;
 
-    hr = IXAudio2_QueryInterface(xa2, &IID_IXAudio27, (void**)&xa27);
+    hr = xaudio2_initialize(impl_from_IXAudio2(xa2), flags, proc);
     if(FAILED(hr)){
         IXAudio2_Release(xa2);
         return hr;
     }
 
-    hr = IXAudio27_Initialize(xa27, flags, proc);
-    if(FAILED(hr)){
-        IXAudio27_Release(xa27);
-        IXAudio2_Release(xa2);
-        return hr;
-    }
-
-    IXAudio27_Release(xa27);
-
     *ppxa2 = xa2;
 
     return S_OK;
diff --git a/dlls/xaudio2_7/xaudio_private.h b/dlls/xaudio2_7/xaudio_private.h
index a75f721..39ed2c8 100644
--- a/dlls/xaudio2_7/xaudio_private.h
+++ b/dlls/xaudio2_7/xaudio_private.h
@@ -150,3 +150,4 @@ extern const IXAudio20SubmixVoiceVtbl XAudio20SubmixVoice_Vtbl DECLSPEC_HIDDEN;
 extern const IXAudio20MasteringVoiceVtbl XAudio20MasteringVoice_Vtbl DECLSPEC_HIDDEN;
 
 extern IClassFactory *make_xapo_factory(REFCLSID clsid) DECLSPEC_HIDDEN;
+extern HRESULT xaudio2_initialize(IXAudio2Impl *This, UINT32 flags, XAUDIO2_PROCESSOR proc) DECLSPEC_HIDDEN;




More information about the wine-cvs mailing list