[Wine-devel] Eter's patch is applied to winehq repo 01/21/11

builder на builder.office.etersoft.ru builder на builder.office.etersoft.ru
Пт Янв 21 20:20:25 MSK 2011


New Etersoft's patches since last build time:
commit 692437f556ba8744c768a8fc196c039b2b5f0203
Author: Alexander Morozov <amorozov на etersoft.ru>

    shell32: Implement IDispatch methods of IShellDispatch.

---

commit 692437f556ba8744c768a8fc196c039b2b5f0203
Author: Alexander Morozov <amorozov на etersoft.ru>
Date:   Thu Jan 20 15:55:48 2011 +0300

    shell32: Implement IDispatch methods of IShellDispatch.

diff --git a/dlls/shell32/shelldispatch.c b/dlls/shell32/shelldispatch.c
index 8d71395..9b2422b 100644
--- a/dlls/shell32/shelldispatch.c
+++ b/dlls/shell32/shelldispatch.c
@@ -39,6 +39,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(shell);
 typedef struct {
     IShellDispatch IShellDispatch_iface;
     LONG ref;
+    ITypeInfo *iTypeInfo;
 } ShellDispatch;
 
 static inline ShellDispatch *impl_from_IShellDispatch(IShellDispatch *iface)
@@ -46,6 +47,26 @@ static inline ShellDispatch *impl_from_IShellDispatch(IShellDispatch *iface)
     return CONTAINING_RECORD(iface, ShellDispatch, IShellDispatch_iface);
 }
 
+static HRESULT load_type_info(REFGUID guid, ITypeInfo **pptinfo)
+{
+    ITypeLib *typelib;
+    HRESULT ret;
+
+    ret = LoadRegTypeLib(&LIBID_Shell32, 1, 0, LOCALE_SYSTEM_DEFAULT, &typelib);
+    if (FAILED(ret))
+    {
+        ERR("LoadRegTypeLib failed: %08x\n", ret);
+        return ret;
+    }
+
+    ret = ITypeLib_GetTypeInfoOfGuid(typelib, guid, pptinfo);
+    ITypeLib_Release(typelib);
+    if (FAILED(ret))
+        ERR("failed to load ITypeInfo\n");
+
+    return ret;
+}
+
 static HRESULT WINAPI ShellDispatch_QueryInterface(IShellDispatch *iface,
         REFIID riid, LPVOID *ppv)
 {
@@ -87,34 +108,43 @@ static ULONG WINAPI ShellDispatch_Release(IShellDispatch *iface)
     TRACE("(%p), new refcount=%i\n", iface, ref);
 
     if (!ref)
+    {
+        ITypeInfo_Release(This->iTypeInfo);
         HeapFree(GetProcessHeap(), 0, This);
+    }
     return ref;
 }
 
 static HRESULT WINAPI ShellDispatch_GetTypeInfoCount(IShellDispatch *iface,
         UINT *pctinfo)
 {
-    FIXME("(%p,%p)\n", iface, pctinfo);
+    TRACE("(%p,%p)\n", iface, pctinfo);
 
-    return E_NOTIMPL;
+    *pctinfo = 1;
+    return S_OK;
 }
 
 static HRESULT WINAPI ShellDispatch_GetTypeInfo(IShellDispatch *iface,
         UINT iTInfo, LCID lcid, ITypeInfo **ppTInfo)
 {
-    FIXME("(%p,%u,%d,%p)\n", iface, iTInfo, lcid, ppTInfo);
+    ShellDispatch *This = impl_from_IShellDispatch(iface);
 
-    *ppTInfo = NULL;
-    return E_NOTIMPL;
+    TRACE("(%p,%u,%d,%p)\n", iface, iTInfo, lcid, ppTInfo);
+
+    ITypeInfo_AddRef(This->iTypeInfo);
+    *ppTInfo = This->iTypeInfo;
+    return S_OK;
 }
 
 static HRESULT WINAPI ShellDispatch_GetIDsOfNames(IShellDispatch *iface,
         REFIID riid, LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
 {
-    FIXME("(%p,%p,%p,%u,%d,%p)\n", iface, riid, rgszNames, cNames, lcid,
+    ShellDispatch *This = impl_from_IShellDispatch(iface);
+
+    TRACE("(%p,%p,%p,%u,%d,%p)\n", iface, riid, rgszNames, cNames, lcid,
             rgDispId);
 
-    return E_NOTIMPL;
+    return ITypeInfo_GetIDsOfNames(This->iTypeInfo, rgszNames, cNames, rgDispId);
 }
 
 static HRESULT WINAPI ShellDispatch_Invoke(IShellDispatch *iface,
@@ -122,10 +152,13 @@ static HRESULT WINAPI ShellDispatch_Invoke(IShellDispatch *iface,
         DISPPARAMS *pDispParams, VARIANT *pVarResult, EXCEPINFO *pExcepInfo,
         UINT *puArgErr)
 {
-    FIXME("(%p,%d,%p,%d,%u,%p,%p,%p,%p)\n", iface, dispIdMember, riid, lcid,
+    ShellDispatch *This = impl_from_IShellDispatch(iface);
+
+    TRACE("(%p,%d,%p,%d,%u,%p,%p,%p,%p)\n", iface, dispIdMember, riid, lcid,
             wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
 
-    return E_NOTIMPL;
+    return ITypeInfo_Invoke(This->iTypeInfo, This, dispIdMember, wFlags,
+            pDispParams, pVarResult, pExcepInfo, puArgErr);
 }
 
 static HRESULT WINAPI ShellDispatch_get_Application(IShellDispatch *iface,
@@ -350,6 +383,13 @@ HRESULT WINAPI IShellDispatch_Constructor(IUnknown *pUnkOuter, REFIID riid,
     This->IShellDispatch_iface.lpVtbl = &ShellDispatch_Vtbl;
     This->ref = 1;
 
+    ret = load_type_info(&IID_IShellDispatch, &This->iTypeInfo);
+    if (FAILED(ret))
+    {
+        HeapFree(GetProcessHeap(), 0, This);
+        return ret;
+    }
+
     ret = ShellDispatch_QueryInterface(&This->IShellDispatch_iface, riid, ppv);
     ShellDispatch_Release(&This->IShellDispatch_iface);
     return ret;


Подробная информация о списке рассылки Wine-devel