[RSHELL]
authorDavid Quintana <gigaherz@gmail.com>
Wed, 19 Feb 2014 12:19:50 +0000 (12:19 +0000)
committerDavid Quintana <gigaherz@gmail.com>
Wed, 19 Feb 2014 12:19:50 +0000 (12:19 +0000)
* Improve the logging system to allow using the same logger for both windows classes and rshell classes.
* Add a wrapper for CMenuSite.
* CMenuDeskBar: Reduce the log differences by keeping a cached copy of the client HWND.
* CMenuBand: Reduce the log differences by keeping a copy of the top level HWND. Will be used later.
CORE-7586

svn path=/branches/shell-experiments/; revision=62253

base/shell/rshell/CMakeLists.txt
base/shell/rshell/CMenuBand.cpp
base/shell/rshell/CMenuDeskBar.cpp
base/shell/rshell/CStartMenu.cpp
base/shell/rshell/logging/CMenuBandWrap.cpp
base/shell/rshell/logging/CMenuDeskBarWrap.cpp
base/shell/rshell/logging/CMenuSiteWrap.cpp [new file with mode: 0644]
base/shell/rshell/precomp.h
base/shell/rshell/wraplog.cpp

index 727e012..f224d88 100644 (file)
@@ -16,6 +16,7 @@ list(APPEND SOURCE
     wraplog.cpp
     logging/CMenuBandWrap.cpp
     logging/CMenuDeskBarWrap.cpp
+    logging/CMenuSiteWrap.cpp
     ${CMAKE_CURRENT_BINARY_DIR}/rshell.def)
 
 add_library(rshell SHARED ${SOURCE})
index 633f3d7..e08e769 100644 (file)
@@ -19,6 +19,7 @@
 */
 #include "precomp.h"
 #include <windowsx.h>
+#include <shlwapi_undoc.h>
 
 WINE_DEFAULT_DEBUG_CHANNEL(CMenuBand);
 
@@ -147,6 +148,8 @@ private:
 
     BOOL m_useBigIcons;
 
+    HWND m_topLevelWindow;
+
 public:
 
     // *** IDeskBand methods ***
@@ -463,19 +466,27 @@ HRESULT CMenuToolbarBase::PopupSubMenu(UINT index, IShellMenu* childShellMenu)
 #endif
     if (FAILED(hr))
         return hr;
+#if WRAP_MENUSITE
+    hr = CMenuSite_Wrapper(pBandSite, IID_PPV_ARG(IBandSite, &pBandSite));
+    if (FAILED(hr))
+        return hr;
+#endif
 
 #if USE_SYSTEM_MENUDESKBAR
     hr = CoCreateInstance(CLSID_MenuDeskBar,
         NULL,
         CLSCTX_INPROC_SERVER,
         IID_PPV_ARG(IDeskBar, &pDeskBar));
-#elif WRAP_MENUDESKBAR
-    hr = CMenuDeskBar_Wrapper(IID_PPV_ARG(IDeskBar, &pDeskBar));
 #else
     hr = CMenuDeskBar_Constructor(IID_PPV_ARG(IDeskBar, &pDeskBar));
 #endif
     if (FAILED(hr))
         return hr;
+#if WRAP_MENUDESKBAR
+    hr = CMenuDeskBar_Wrapper(pDeskBar, IID_PPV_ARG(IDeskBar, &pDeskBar));
+    if (FAILED(hr))
+        return hr;
+#endif
 
     hr = pDeskBar->SetClient(pBandSite);
     if (FAILED(hr))
@@ -868,13 +879,16 @@ HRESULT CMenuSFToolbar::PopupItem(UINT uItem)
         NULL,
         CLSCTX_INPROC_SERVER,
         IID_PPV_ARG(IShellMenu, &shellMenu));
-#elif WRAP_MENUBAND
-    hr = CMenuBand_Wrapper(IID_PPV_ARG(IShellMenu, &shellMenu));
 #else
     hr = CMenuBand_Constructor(IID_PPV_ARG(IShellMenu, &shellMenu));
 #endif
     if (FAILED(hr))
         return hr;
+#if WRAP_MENUBAND
+    hr = CMenuBand_Wrapper(shellMenu, IID_PPV_ARG(IShellMenu, &shellMenu));
+    if (FAILED(hr))
+        return hr;
+#endif
 
     m_menuBand->GetMenuInfo(&psmc, &uId, &uIdAncestor, &flags);
 
@@ -992,26 +1006,26 @@ HRESULT STDMETHODCALLTYPE  CMenuBand::SetMenu(
     m_hmenu = hmenu;
     m_menuOwner;
 
-    HRESULT hResult = m_staticToolbar->SetMenu(hmenu, hwnd, dwFlags);
-    if (FAILED(hResult))
-        return hResult;
+    HRESULT hr = m_staticToolbar->SetMenu(hmenu, hwnd, dwFlags);
+    if (FAILED(hr))
+        return hr;
 
     if (m_site)
     {
         HWND hwndParent;
 
-        hResult = m_site->GetWindow(&hwndParent);
-        if (FAILED(hResult))
-            return hResult;
+        hr = m_site->GetWindow(&hwndParent);
+        if (FAILED(hr))
+            return hr;
 
-        hResult = m_staticToolbar->CreateToolbar(hwndParent, m_dwFlags);
-        if (FAILED(hResult))
-            return hResult;
+        hr = m_staticToolbar->CreateToolbar(hwndParent, m_dwFlags);
+        if (FAILED(hr))
+            return hr;
 
-        hResult = m_staticToolbar->FillToolbar();
+        hr = m_staticToolbar->FillToolbar();
     }
 
-    return hResult;
+    return hr;
 }
 
 HRESULT STDMETHODCALLTYPE  CMenuBand::GetMenu(
@@ -1027,8 +1041,8 @@ HRESULT STDMETHODCALLTYPE  CMenuBand::GetMenu(
 
 HRESULT STDMETHODCALLTYPE  CMenuBand::SetSite(IUnknown *pUnkSite)
 {
-    HWND                    hwndParent;
-    HRESULT                 hResult;
+    HWND    hwndParent;
+    HRESULT hr;
 
     if (m_site != NULL)
         m_site->Release();
@@ -1037,34 +1051,47 @@ HRESULT STDMETHODCALLTYPE  CMenuBand::SetSite(IUnknown *pUnkSite)
         return S_OK;
 
     hwndParent = NULL;
-    hResult = pUnkSite->QueryInterface(IID_PPV_ARG(IOleWindow, &m_site));
-    if (SUCCEEDED(hResult))
+    hr = pUnkSite->QueryInterface(IID_PPV_ARG(IOleWindow, &m_site));
+    if (SUCCEEDED(hr))
     {
-        m_site->GetWindow(&hwndParent);
         m_site->Release();
+
+        hr = m_site->GetWindow(&hwndParent);
+        if (FAILED(hr))
+            return hr;
     }
+
     if (!::IsWindow(hwndParent))
         return E_FAIL;
 
     if (m_staticToolbar != NULL)
     {
-        hResult = m_staticToolbar->CreateToolbar(hwndParent, m_dwFlags);
-        if (FAILED(hResult))
-            return hResult;
+        hr = m_staticToolbar->CreateToolbar(hwndParent, m_dwFlags);
+        if (FAILED(hr))
+            return hr;
 
-        hResult = m_staticToolbar->FillToolbar();
+        hr = m_staticToolbar->FillToolbar();
+        if (FAILED(hr))
+            return hr;
     }
 
     if (m_SFToolbar != NULL)
     {
-        hResult = m_SFToolbar->CreateToolbar(hwndParent, m_dwFlags);
-        if (FAILED(hResult))
-            return hResult;
+        hr = m_SFToolbar->CreateToolbar(hwndParent, m_dwFlags);
+        if (FAILED(hr))
+            return hr;
 
-        hResult = m_SFToolbar->FillToolbar();
+        hr = m_SFToolbar->FillToolbar();
+        if (FAILED(hr))
+            return hr;
     }
 
-    return S_OK;
+    CComPtr<IOleWindow> pTopLevelWindow;
+    hr = IUnknown_QueryService(m_site, SID_STopLevelBrowser, IID_PPV_ARG(IOleWindow, &pTopLevelWindow));
+    if (FAILED(hr))
+        return hr;
+
+    return pTopLevelWindow->GetWindow(&m_topLevelWindow);
 }
 
 HRESULT STDMETHODCALLTYPE  CMenuBand::GetSite(REFIID riid, PVOID *ppvSite)
@@ -1093,17 +1120,17 @@ HRESULT STDMETHODCALLTYPE CMenuBand::OnPosRectChangeDB(RECT *prc)
     SIZE sizeShlFldY = { 0 };
     HWND hwndStatic = NULL;
     HWND hwndShlFld = NULL;
-    HRESULT hResult = S_OK;
+    HRESULT hr = S_OK;
 
     if (m_staticToolbar != NULL)
-        hResult = m_staticToolbar->GetWindow(&hwndStatic);
-    if (FAILED(hResult))
-        return hResult;
+        hr = m_staticToolbar->GetWindow(&hwndStatic);
+    if (FAILED(hr))
+        return hr;
 
     if (m_SFToolbar != NULL)
-        hResult = m_SFToolbar->GetWindow(&hwndShlFld);
-    if (FAILED(hResult))
-        return hResult;
+        hr = m_SFToolbar->GetWindow(&hwndShlFld);
+    if (FAILED(hr))
+        return hr;
 
     if (hwndStatic == NULL && hwndShlFld == NULL)
         return E_FAIL;
@@ -1146,17 +1173,17 @@ HRESULT STDMETHODCALLTYPE  CMenuBand::GetBandInfo(
 {
     HWND hwndStatic = NULL;
     HWND hwndShlFld = NULL;
-    HRESULT hResult = S_OK;
+    HRESULT hr = S_OK;
 
     if (m_staticToolbar != NULL)
-        hResult = m_staticToolbar->GetWindow(&hwndStatic);
-    if (FAILED(hResult))
-        return hResult;
+        hr = m_staticToolbar->GetWindow(&hwndStatic);
+    if (FAILED(hr))
+        return hr;
 
     if (m_SFToolbar != NULL)
-        hResult = m_SFToolbar->GetWindow(&hwndShlFld);
-    if (FAILED(hResult))
-        return hResult;
+        hr = m_SFToolbar->GetWindow(&hwndShlFld);
+    if (FAILED(hr))
+        return hr;
 
     if (hwndStatic == NULL && hwndShlFld == NULL)
         return E_FAIL;
@@ -1401,26 +1428,26 @@ HRESULT STDMETHODCALLTYPE CMenuBand::SetShellFolder(IShellFolder *psf, LPCITEMID
         m_SFToolbar = new CMenuSFToolbar(this);
     }
 
-    HRESULT hResult = m_SFToolbar->SetShellFolder(psf, pidlFolder, hKey, dwFlags);
-    if (FAILED(hResult))
-        return hResult;
+    HRESULT hr = m_SFToolbar->SetShellFolder(psf, pidlFolder, hKey, dwFlags);
+    if (FAILED(hr))
+        return hr;
 
     if (m_site)
     {
         HWND hwndParent;
 
-        hResult = m_site->GetWindow(&hwndParent);
-        if (FAILED(hResult))
-            return hResult;
+        hr = m_site->GetWindow(&hwndParent);
+        if (FAILED(hr))
+            return hr;
 
-        hResult = m_SFToolbar->CreateToolbar(hwndParent, m_dwFlags);
-        if (FAILED(hResult))
-            return hResult;
+        hr = m_SFToolbar->CreateToolbar(hwndParent, m_dwFlags);
+        if (FAILED(hr))
+            return hr;
 
-        hResult = m_SFToolbar->FillToolbar();
+        hr = m_SFToolbar->FillToolbar();
     }
 
-    return hResult;
+    return hr;
 }
 
 HRESULT STDMETHODCALLTYPE CMenuBand::GetShellFolder(DWORD *pdwFlags, LPITEMIDLIST *ppidl, REFIID riid, void **ppv)
index d0be84e..bed852b 100644 (file)
@@ -50,6 +50,8 @@ private:
     CComPtr<IUnknown>   m_Client;
     CComPtr<IMenuPopup> m_SubMenuParent;
 
+    HWND m_ClientWindow;
+
     DWORD m_IconSize;
     HBITMAP m_Banner;
 
@@ -255,7 +257,7 @@ HRESULT STDMETHODCALLTYPE CMenuDeskBar::TranslateAcceleratorIO(LPMSG lpMsg)
 HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetClient(IUnknown *punkClient)
 {
     CComPtr<IDeskBarClient> pDeskBandClient;
-    HRESULT hResult;
+    HRESULT hr;
 
     m_Client.Release();
 
@@ -267,15 +269,19 @@ HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetClient(IUnknown *punkClient)
         Create(NULL);
     }
 
-    hResult = punkClient->QueryInterface(IID_IUnknown, reinterpret_cast<void **>(&m_Client));
-    if (FAILED(hResult))
-        return hResult;
+    hr = punkClient->QueryInterface(IID_PPV_ARG(IUnknown, &m_Client));
+    if (FAILED(hr))
+        return hr;
 
-    hResult = m_Client->QueryInterface(IID_IDeskBarClient, (VOID**) &pDeskBandClient);
-    if (FAILED(hResult))
-        return hResult;
+    hr = m_Client->QueryInterface(IID_PPV_ARG(IDeskBarClient, &pDeskBandClient));
+    if (FAILED(hr))
+        return hr;
 
-    return pDeskBandClient->SetDeskBarSite(static_cast<IDeskBar*>(this));
+    hr = pDeskBandClient->SetDeskBarSite(static_cast<IDeskBar*>(this));
+    if (FAILED(hr))
+        return hr;
+
+    return IUnknown_GetWindow(m_Client, &m_ClientWindow);
 }
 
 HRESULT STDMETHODCALLTYPE CMenuDeskBar::GetClient(IUnknown **ppunkClient)
@@ -317,17 +323,6 @@ LRESULT CMenuDeskBar::OnSize(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHan
 
     if (m_Client)
     {
-        CComPtr<IOleWindow> pOw;
-        hr = m_Client->QueryInterface(IID_PPV_ARG(IOleWindow, &pOw));
-        if (FAILED(hr))
-        {
-            ERR("IUnknown_QueryInterface pBs failed: %x\n", hr);
-            return 0;
-        }
-
-        HWND clientWnd;
-        pOw->GetWindow(&clientWnd);
-
         RECT rc;
 
         GetClientRect(&rc);
@@ -339,7 +334,7 @@ LRESULT CMenuDeskBar::OnSize(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHan
             rc.left += bm.bmWidth;
         }
 
-        ::SetWindowPos(clientWnd, NULL, rc.left, rc.top, rc.right - rc.left, rc.bottom - rc.top, 0);
+        ::SetWindowPos(m_ClientWindow, NULL, rc.left, rc.top, rc.right - rc.left, rc.bottom - rc.top, 0);
     }
 
     return 0;
@@ -349,14 +344,14 @@ LRESULT CMenuDeskBar::OnNotify(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bH
 {
     CComPtr<IWinEventHandler>               winEventHandler;
     LRESULT                                 result;
-    HRESULT                                 hResult;
+    HRESULT                                 hr;
 
     result = 0;
     if (m_Client.p != NULL)
     {
-        hResult = m_Client->QueryInterface(IID_IWinEventHandler, reinterpret_cast<void **>(&winEventHandler));
-        if (SUCCEEDED(hResult) && winEventHandler.p != NULL)
-            hResult = winEventHandler->OnWinEvent(NULL, uMsg, wParam, lParam, &result);
+        hr = m_Client->QueryInterface(IID_PPV_ARG(IWinEventHandler, &winEventHandler));
+        if (SUCCEEDED(hr) && winEventHandler.p != NULL)
+            hr = winEventHandler->OnWinEvent(NULL, uMsg, wParam, lParam, &result);
     }
     return result;
 }
@@ -425,6 +420,9 @@ HRESULT STDMETHODCALLTYPE CMenuDeskBar::Popup(POINTL *ppt, RECTL *prcExclude, MP
     if (FAILED(hr))
         return hr;
 
+    hr = dbc->SetModeDBC(1);
+    // Allow it to fail with E_NOTIMPL.
+
     // No clue about the arg, using anything != 0
     hr = dbc->UIActivateDBC(TRUE);
     if (FAILED(hr))
index de7e75c..d1b324c 100644 (file)
@@ -144,6 +144,13 @@ private:
 #else
         hr = CMenuBand_Constructor(IID_PPV_ARG(IShellMenu, &pShellMenu));
 #endif
+        if (FAILED(hr))
+            return hr;
+#if WRAP_MENUBAND
+        hr = CMenuBand_Wrapper(pShellMenu, IID_PPV_ARG(IShellMenu, &pShellMenu));
+        if (FAILED(hr))
+            return hr;
+#endif
 
         hr = pShellMenu->Initialize(this, 0, ANCESTORDEFAULT, SMINIT_VERTICAL);
 
@@ -276,13 +283,16 @@ CStartMenu_Constructor(REFIID riid, void **ppv)
                           NULL,
                           CLSCTX_INPROC_SERVER,
                           IID_PPV_ARG(IShellMenu, &pShellMenu));
-#elif WRAP_MENUBAND
-    hr = CMenuBand_Wrapper(IID_PPV_ARG(IShellMenu, &pShellMenu));
 #else
     hr = CMenuBand_Constructor(IID_PPV_ARG(IShellMenu, &pShellMenu));
 #endif
     if (FAILED(hr))
         return hr;
+#if WRAP_MENUBAND
+    hr = CMenuBand_Wrapper(pShellMenu, IID_PPV_ARG(IShellMenu, &pShellMenu));
+    if (FAILED(hr))
+        return hr;
+#endif
 
 #if USE_SYSTEM_MENUSITE
     hr = CoCreateInstance(CLSID_MenuBandSite,
@@ -294,19 +304,27 @@ CStartMenu_Constructor(REFIID riid, void **ppv)
 #endif
     if (FAILED(hr))
         return hr;
+#if WRAP_MENUSITE
+    hr = CMenuSite_Wrapper(pBandSite, IID_PPV_ARG(IBandSite, &pBandSite));
+    if (FAILED(hr))
+        return hr;
+#endif
 
 #if USE_SYSTEM_MENUDESKBAR
     hr = CoCreateInstance(CLSID_MenuDeskBar,
                           NULL,
                           CLSCTX_INPROC_SERVER,
                           IID_PPV_ARG(IDeskBar, &pDeskBar));
-#elif WRAP_MENUDESKBAR
-    hr = CMenuDeskBar_Wrapper(IID_PPV_ARG(IDeskBar, &pDeskBar));
 #else
     hr = CMenuDeskBar_Constructor(IID_PPV_ARG(IDeskBar, &pDeskBar));
 #endif
     if (FAILED(hr))
         return hr;
+#if WRAP_MENUDESKBAR
+    hr = CMenuDeskBar_Wrapper(pDeskBar, IID_PPV_ARG(IDeskBar, &pDeskBar));
+    if (FAILED(hr))
+        return hr;
+#endif
 
     CComObject<CShellMenuCallback> *pCallback;
     hr = CComObject<CShellMenuCallback>::CreateInstance(&pCallback);
index 6015e39..c10756a 100644 (file)
-/*\r
-* Shell Menu Band\r
-*\r
-* Copyright 2014 David Quintana\r
-*\r
-* This library is free software; you can redistribute it and/or\r
-* modify it under the terms of the GNU Lesser General Public\r
-* License as published by the Free Software Foundation; either\r
-* version 2.1 of the License, or (at your option) any later version.\r
-*\r
-* This library is distributed in the hope that it will be useful,\r
-* but WITHOUT ANY WARRANTY; without even the implied warranty of\r
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\r
-* Lesser General Public License for more details.\r
-*\r
-* You should have received a copy of the GNU Lesser General Public\r
-* License along with this library; if not, write to the Free Software\r
-* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA\r
-*/\r
-#include "precomp.h"\r
-#include "wraplog.h"\r
-\r
-WINE_DEFAULT_DEBUG_CHANNEL(CMenuBandWrap);\r
-\r
-class CMenuBandWrap :\r
-    public CComCoClass<CMenuBandWrap>,\r
-    public CComObjectRootEx<CComMultiThreadModelNoCS>,\r
-    public IDeskBand,\r
-    public IObjectWithSite,\r
-    public IInputObject,\r
-    public IPersistStream,\r
-    public IOleCommandTarget,\r
-    public IServiceProvider,\r
-    public IMenuPopup,\r
-    public IMenuBand,\r
-    public IShellMenu2,\r
-    public IWinEventHandler,\r
-    public IShellMenuAcc\r
-{\r
-public:\r
-    CMenuBandWrap();\r
-    ~CMenuBandWrap();\r
-\r
-private:\r
-    IUnknown          * m_IUnknown;\r
-    IDeskBand         * m_IDeskBand;\r
-    IDockingWindow    * m_IDockingWindow;\r
-    IOleWindow        * m_IOleWindow;\r
-    IObjectWithSite   * m_IObjectWithSite;\r
-    IInputObject      * m_IInputObject;\r
-    IPersistStream    * m_IPersistStream;\r
-    IPersist          * m_IPersist;\r
-    IOleCommandTarget * m_IOleCommandTarget;\r
-    IServiceProvider  * m_IServiceProvider;\r
-    IMenuPopup        * m_IMenuPopup;\r
-    IDeskBar          * m_IDeskBar;\r
-    IMenuBand         * m_IMenuBand;\r
-    IShellMenu2       * m_IShellMenu2;\r
-    IShellMenu        * m_IShellMenu;\r
-    IWinEventHandler  * m_IWinEventHandler;\r
-    IShellMenuAcc     * m_IShellMenuAcc;\r
-\r
-    BOOL m_useBigIcons;\r
-\r
-public:\r
-\r
-    // *** IDeskBand methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE GetBandInfo(DWORD dwBandID, DWORD dwViewMode, DESKBANDINFO *pdbi);\r
-\r
-    // *** IDockingWindow methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE ShowDW(BOOL fShow);\r
-    virtual HRESULT STDMETHODCALLTYPE CloseDW(DWORD dwReserved);\r
-    virtual HRESULT STDMETHODCALLTYPE ResizeBorderDW(LPCRECT prcBorder, IUnknown *punkToolbarSite, BOOL fReserved);\r
-\r
-    // *** IOleWindow methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE GetWindow(HWND *phwnd);\r
-    virtual HRESULT STDMETHODCALLTYPE ContextSensitiveHelp(BOOL fEnterMode);\r
-\r
-    // *** IObjectWithSite methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE SetSite(IUnknown *pUnkSite);\r
-    virtual HRESULT STDMETHODCALLTYPE GetSite(REFIID riid, PVOID *ppvSite);\r
-\r
-    // *** IInputObject methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE UIActivateIO(BOOL fActivate, LPMSG lpMsg);\r
-    virtual HRESULT STDMETHODCALLTYPE HasFocusIO();\r
-    virtual HRESULT STDMETHODCALLTYPE TranslateAcceleratorIO(LPMSG lpMsg);\r
-\r
-    // *** IPersistStream methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE IsDirty();\r
-    virtual HRESULT STDMETHODCALLTYPE Load(IStream *pStm);\r
-    virtual HRESULT STDMETHODCALLTYPE Save(IStream *pStm, BOOL fClearDirty);\r
-    virtual HRESULT STDMETHODCALLTYPE GetSizeMax(ULARGE_INTEGER *pcbSize);\r
-\r
-    // *** IPersist methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE GetClassID(CLSID *pClassID);\r
-\r
-    // *** IOleCommandTarget methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText);\r
-    virtual HRESULT STDMETHODCALLTYPE Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut);\r
-\r
-    // *** IServiceProvider methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE QueryService(REFGUID guidService, REFIID riid, void **ppvObject);\r
-\r
-    // *** IMenuPopup methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE OnSelect(DWORD dwSelectType);\r
-    virtual HRESULT STDMETHODCALLTYPE SetSubMenu(IMenuPopup *pmp, BOOL fSet);\r
-\r
-    // *** IDeskBar methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE SetClient(IUnknown *punkClient);\r
-    virtual HRESULT STDMETHODCALLTYPE GetClient(IUnknown **ppunkClient);\r
-    virtual HRESULT STDMETHODCALLTYPE OnPosRectChangeDB(RECT *prc);\r
-\r
-    // *** IMenuBand methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE IsMenuMessage(MSG *pmsg);\r
-    virtual HRESULT STDMETHODCALLTYPE TranslateMenuMessage(MSG *pmsg, LRESULT *plRet);\r
-\r
-    // *** IShellMenu methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE Initialize(IShellMenuCallback *psmc, UINT uId, UINT uIdAncestor, DWORD dwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE GetMenuInfo(IShellMenuCallback **ppsmc, UINT *puId, UINT *puIdAncestor, DWORD *pdwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE SetShellFolder(IShellFolder *psf, LPCITEMIDLIST pidlFolder, HKEY hKey, DWORD dwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE GetShellFolder(DWORD *pdwFlags, LPITEMIDLIST *ppidl, REFIID riid, void **ppv);\r
-    virtual HRESULT STDMETHODCALLTYPE SetMenu(HMENU hmenu, HWND hwnd, DWORD dwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE GetMenu(HMENU *phmenu, HWND *phwnd, DWORD *pdwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE InvalidateItem(LPSMDATA psmd, DWORD dwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE GetState(LPSMDATA psmd);\r
-    virtual HRESULT STDMETHODCALLTYPE SetMenuToolbar(IUnknown *punk, DWORD dwFlags);\r
-\r
-    // *** IWinEventHandler methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE OnWinEvent(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *theResult);\r
-    virtual HRESULT STDMETHODCALLTYPE IsWindowOwner(HWND hWnd);\r
-\r
-    // *** IShellMenu2 methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE GetSubMenu(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE SetToolbar(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE SetMinWidth(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE SetNoBorder(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE SetTheme(THIS);\r
-\r
-    // *** IShellMenuAcc methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE GetTop(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE GetBottom(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE GetTracked(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE GetParentSite(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE GetState(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE DoDefaultAction(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE IsEmpty(THIS);\r
-\r
-    DECLARE_NOT_AGGREGATABLE(CMenuBandWrap)\r
-    DECLARE_PROTECT_FINAL_CONSTRUCT()\r
-\r
-    BEGIN_COM_MAP(CMenuBandWrap)\r
-        COM_INTERFACE_ENTRY_IID(IID_IDeskBar, IMenuPopup)\r
-        COM_INTERFACE_ENTRY_IID(IID_IShellMenu, IShellMenu)\r
-        COM_INTERFACE_ENTRY_IID(IID_IOleCommandTarget, IOleCommandTarget)\r
-        COM_INTERFACE_ENTRY_IID(IID_IOleWindow, IDeskBand)\r
-        COM_INTERFACE_ENTRY_IID(IID_IDockingWindow, IDockingWindow)\r
-        COM_INTERFACE_ENTRY_IID(IID_IDeskBand, IDeskBand)\r
-        COM_INTERFACE_ENTRY_IID(IID_IObjectWithSite, IObjectWithSite)\r
-        COM_INTERFACE_ENTRY_IID(IID_IInputObject, IInputObject)\r
-        COM_INTERFACE_ENTRY_IID(IID_IPersistStream, IPersistStream)\r
-        COM_INTERFACE_ENTRY_IID(IID_IPersist, IPersistStream)\r
-        COM_INTERFACE_ENTRY_IID(IID_IServiceProvider, IServiceProvider)\r
-        COM_INTERFACE_ENTRY_IID(IID_IMenuPopup, IMenuPopup)\r
-        COM_INTERFACE_ENTRY_IID(IID_IMenuBand, IMenuBand)\r
-        COM_INTERFACE_ENTRY_IID(IID_IShellMenu2, IShellMenu2)\r
-        COM_INTERFACE_ENTRY_IID(IID_IWinEventHandler, IWinEventHandler)\r
-        COM_INTERFACE_ENTRY_IID(IID_IShellMenuAcc, IShellMenuAcc)\r
-    END_COM_MAP()\r
-};\r
-\r
-extern "C"\r
-HRESULT CMenuBand_Wrapper(REFIID riid, LPVOID *ppv)\r
-{\r
-    *ppv = NULL;\r
-\r
-    CMenuBandWrap * site = new CComObject<CMenuBandWrap>();\r
-\r
-    if (!site)\r
-        return E_OUTOFMEMORY;\r
-\r
-    HRESULT hr = site->QueryInterface(riid, ppv);\r
-\r
-    if (FAILED(hr))\r
-        site->Release();\r
-\r
-    return hr;\r
-}\r
-\r
-CMenuBandWrap::CMenuBandWrap()\r
-{\r
-    WrapLogOpen();\r
-\r
-    CoCreateInstance(CLSID_MenuBand, NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARG(IShellMenu, &m_IShellMenu));\r
-    m_IShellMenu->QueryInterface(IID_PPV_ARG(IUnknown, &m_IUnknown));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IDeskBand, &m_IDeskBand));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IDockingWindow, &m_IDockingWindow));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IOleWindow, &m_IOleWindow));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IObjectWithSite, &m_IObjectWithSite));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IInputObject, &m_IInputObject));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IPersistStream, &m_IPersistStream));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IPersist, &m_IPersist));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IOleCommandTarget, &m_IOleCommandTarget));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IServiceProvider, &m_IServiceProvider));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IMenuPopup, &m_IMenuPopup));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IDeskBar, &m_IDeskBar));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IMenuBand, &m_IMenuBand));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IShellMenu2, &m_IShellMenu2));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IWinEventHandler, &m_IWinEventHandler));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IShellMenuAcc, &m_IShellMenuAcc));\r
-}\r
-\r
-CMenuBandWrap::~CMenuBandWrap()\r
-{\r
-    m_IUnknown->Release();\r
-    m_IDeskBand->Release();\r
-    m_IDockingWindow->Release();\r
-    m_IOleWindow->Release();\r
-    m_IObjectWithSite->Release();\r
-    m_IInputObject->Release();\r
-    m_IPersistStream->Release();\r
-    m_IPersist->Release();\r
-    m_IOleCommandTarget->Release();\r
-    m_IServiceProvider->Release();\r
-    m_IMenuPopup->Release();\r
-    m_IDeskBar->Release();\r
-    m_IMenuBand->Release();\r
-    m_IShellMenu2->Release();\r
-    m_IShellMenu->Release();\r
-    m_IWinEventHandler->Release();\r
-    m_IShellMenuAcc->Release();\r
-    WrapLogClose();\r
-}\r
-\r
-\r
-// *** IShellMenu2 methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetSubMenu(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetSubMenu()\n", this);\r
-    HRESULT hr = m_IShellMenu2->GetSubMenu();\r
-    WrapLogExit("CMenuBandWrap::GetSubMenu() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetToolbar(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetToolbar()\n", this);\r
-    HRESULT hr = m_IShellMenu2->SetToolbar();\r
-    WrapLogExit("CMenuBandWrap::SetToolbar() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetMinWidth(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetMinWidth()\n", this);\r
-    HRESULT hr = m_IShellMenu2->SetMinWidth();\r
-    WrapLogExit("CMenuBandWrap::SetMinWidth() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetNoBorder(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetNoBorder()\n", this);\r
-    HRESULT hr = m_IShellMenu2->SetNoBorder();\r
-    WrapLogExit("CMenuBandWrap::SetNoBorder() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetTheme(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetTheme()\n", this);\r
-    HRESULT hr = m_IShellMenu2->SetTheme();\r
-    WrapLogExit("CMenuBandWrap::SetTheme() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-\r
-// *** IShellMenuAcc methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetTop(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetTop()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetTop();\r
-    WrapLogExit("CMenuBandWrap::GetTop() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetBottom(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetBottom();\r
-    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetTracked(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetBottom();\r
-    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetParentSite(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetBottom();\r
-    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetState(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetBottom();\r
-    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::DoDefaultAction(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetBottom();\r
-    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsEmpty(THIS)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);\r
-    HRESULT hr = m_IShellMenuAcc->GetBottom();\r
-    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IDeskBand methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetBandInfo(DWORD dwBandID, DWORD dwViewMode, DESKBANDINFO *pdbi)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetBandInfo(DWORD dwBandID=%d, DWORD dwViewMode=%d, DESKBANDINFO *pdbi=%p)\n", this, dwBandID, dwViewMode, pdbi);\r
-    HRESULT hr = m_IDeskBand->GetBandInfo(dwBandID, dwViewMode, pdbi);\r
-    WrapLogExit("CMenuBandWrap::GetBandInfo() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IDockingWindow methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::ShowDW(BOOL fShow)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::ShowDW(BOOL fShow=%d)\n", this, fShow);\r
-    HRESULT hr = m_IDockingWindow->ShowDW(fShow);\r
-    WrapLogExit("CMenuBandWrap::ShowDW() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::CloseDW(DWORD dwReserved)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::CloseDW(DWORD dwReserved=%d)\n", this, dwReserved);\r
-    HRESULT hr = m_IDockingWindow->CloseDW(dwReserved);\r
-    WrapLogExit("CMenuBandWrap::CloseDW() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::ResizeBorderDW(LPCRECT prcBorder, IUnknown *punkToolbarSite, BOOL fReserved)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::ResizeBorderDW(LPCRECT prcBorder=%p, IUnknown *punkToolbarSite=%p, BOOL fReserved=%d)\n", this, prcBorder, punkToolbarSite, fReserved);\r
-    if (prcBorder) WrapLogMsg("*prcBorder=%s\n", Wrap(*prcBorder));\r
-    HRESULT hr = m_IDockingWindow->ResizeBorderDW(prcBorder, punkToolbarSite, fReserved);\r
-    if (prcBorder) WrapLogMsg("*prcBorder=%s\n", Wrap(*prcBorder));\r
-    WrapLogExit("CMenuBandWrap::ResizeBorderDW() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IOleWindow methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetWindow(HWND *phwnd)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetWindow(HWND *phwnd=%p)\n", this, phwnd);\r
-    HRESULT hr = m_IOleWindow->GetWindow(phwnd);\r
-    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);\r
-    WrapLogExit("CMenuBandWrap::GetWindow() = %08x\n", hr);\r
-    return hr;\r
-}\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::ContextSensitiveHelp(BOOL fEnterMode)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::ContextSensitiveHelp(BOOL fEnterMode=%d)\n", this, fEnterMode);\r
-    HRESULT hr = m_IOleWindow->ContextSensitiveHelp(fEnterMode);\r
-    WrapLogExit("CMenuBandWrap::ContextSensitiveHelp() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IWinEventHandler methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::OnWinEvent(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *theResult)\r
-{\r
-    //WrapLogEnter("CMenuBandWrap<%p>::OnWinEvent(HWND hWnd=%p, UINT uMsg=%u, WPARAM wParam=%08x, LPARAM lParam=%08x, LRESULT *theResult=%p)\n", this, hWnd, uMsg, wParam, lParam, theResult);\r
-    HRESULT hr = m_IWinEventHandler->OnWinEvent(hWnd, uMsg, wParam, lParam, theResult);\r
-    //WrapLogExit("CMenuBandWrap::OnWinEvent() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsWindowOwner(HWND hWnd)\r
-{\r
-    //WrapLogEnter("CMenuBandWrap<%p>::IsWindowOwner(HWND hWnd=%08x)\n", this, hWnd);\r
-    HRESULT hr = m_IWinEventHandler->IsWindowOwner(hWnd);\r
-    //WrapLogExit("CMenuBandWrap::IsWindowOwner() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IObjectWithSite methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetSite(IUnknown *pUnkSite)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetSite(IUnknown *pUnkSite=%p)\n", this, pUnkSite);\r
-    HRESULT hr = m_IObjectWithSite->SetSite(pUnkSite);\r
-    WrapLogExit("CMenuBandWrap::SetSite() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetSite(REFIID riid, PVOID *ppvSite)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetSite(REFIID riid=%s, PVOID *ppvSite=%p)\n", this, Wrap(riid), ppvSite);\r
-    HRESULT hr = m_IObjectWithSite->GetSite(riid, ppvSite);\r
-    if (ppvSite) WrapLogMsg("*ppvSite=%p\n", *ppvSite);\r
-    WrapLogExit("CMenuBandWrap::GetSite() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IInputObject methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::UIActivateIO(BOOL fActivate, LPMSG lpMsg)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::UIActivateIO(BOOL fActivate=%d, LPMSG lpMsg=%p)\n", this, fActivate, lpMsg);\r
-    HRESULT hr = m_IInputObject->UIActivateIO(fActivate, lpMsg);\r
-    WrapLogExit("CMenuBandWrap::UIActivateIO() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::HasFocusIO()\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::HasFocusIO()\n", this);\r
-    HRESULT hr = m_IInputObject->HasFocusIO();\r
-    WrapLogExit("CMenuBandWrap::HasFocusIO() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::TranslateAcceleratorIO(LPMSG lpMsg)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::TranslateAcceleratorIO(LPMSG lpMsg=%p)\n", this, lpMsg);\r
-    if (lpMsg) WrapLogMsg("*lpMsg=%s\n", Wrap(*lpMsg));\r
-    HRESULT hr = m_IInputObject->TranslateAcceleratorIO(lpMsg);\r
-    WrapLogExit("CMenuBandWrap::TranslateAcceleratorIO() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IPersistStream methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsDirty()\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::IsDirty()\n", this);\r
-    HRESULT hr = m_IPersistStream->IsDirty();\r
-    WrapLogExit("CMenuBandWrap::IsDirty() = %08x\n", hr);\r
-    return hr;\r
-}\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::Load(IStream *pStm)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::Load(IStream *pStm=%p)\n", this, pStm);\r
-    HRESULT hr = m_IPersistStream->Load(pStm);\r
-    WrapLogExit("CMenuBandWrap::Load() = %08x\n", hr);\r
-    return hr;\r
-}\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::Save(IStream *pStm, BOOL fClearDirty)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::Save(IStream *pStm=%p, BOOL fClearDirty=%d)\n", this, pStm, fClearDirty);\r
-    HRESULT hr = m_IPersistStream->Save(pStm, fClearDirty);\r
-    WrapLogExit("CMenuBandWrap::Save() = %08x\n", hr);\r
-    return hr;\r
-}\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetSizeMax(ULARGE_INTEGER *pcbSize)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetSizeMax(ULARGE_INTEGER *pcbSize=%p)\n", this, pcbSize);\r
-    HRESULT hr = m_IPersistStream->GetSizeMax(pcbSize);\r
-    WrapLogExit("CMenuBandWrap::GetSizeMax() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IPersist methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetClassID(CLSID *pClassID)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetClassID(CLSID *pClassID=%p)\n", this, pClassID);\r
-    HRESULT hr = m_IPersist->GetClassID(pClassID);\r
-    if (pClassID) WrapLogMsg("*pClassID=%s\n", Wrap(*pClassID));\r
-    WrapLogExit("CMenuBandWrap::GetClassID() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IOleCommandTarget methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::QueryStatus(const GUID *pguidCmdGroup=%p, ULONG cCmds=%u, prgCmds=%p, pCmdText=%p)\n", this, pguidCmdGroup, cCmds, prgCmds, pCmdText);\r
-    HRESULT hr = m_IOleCommandTarget->QueryStatus(pguidCmdGroup, cCmds, prgCmds, pCmdText);\r
-    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));\r
-    WrapLogExit("CMenuBandWrap::QueryStatus() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::Exec(const GUID *pguidCmdGroup=%p, DWORD nCmdID=%d, DWORD nCmdexecopt=%d, VARIANT *pvaIn=%p, VARIANT *pvaOut=%p)\n", this, pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);\r
-    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));\r
-    HRESULT hr = m_IOleCommandTarget->Exec(pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);\r
-    WrapLogExit("CMenuBandWrap::Exec() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IServiceProvider methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::QueryService(REFGUID guidService, REFIID riid, void **ppvObject)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::QueryService(REFGUID guidService=%s, REFIID riid=%s, void **ppvObject=%p)\n", this, Wrap(guidService), Wrap(riid), ppvObject);\r
-\r
-    if (IsEqualIID(guidService, SID_SMenuBandChild))\r
-    {\r
-        WrapLogMsg("SID is SID_SMenuBandChild. Using QueryInterface of self instead of wrapped object.\n");\r
-        HRESULT hr = this->QueryInterface(riid, ppvObject);\r
-        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-        if (SUCCEEDED(hr))\r
-        {\r
-            WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);\r
-            return hr;\r
-        }\r
-        else\r
-        {\r
-            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");\r
-        }\r
-    }\r
-    else if (IsEqualIID(guidService, SID_SMenuBandBottom))\r
-    {\r
-        WrapLogMsg("SID is SID_SMenuBandBottom. Using QueryInterface of self instead of wrapped object.\n");\r
-        HRESULT hr = this->QueryInterface(riid, ppvObject);\r
-        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-        if (SUCCEEDED(hr))\r
-        {\r
-            WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);\r
-            return hr;\r
-        }\r
-        else\r
-        {\r
-            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");\r
-        }\r
-    }\r
-    else if (IsEqualIID(guidService, SID_SMenuBandBottomSelected))\r
-    {\r
-        WrapLogMsg("SID is SID_SMenuBandBottomSelected. Using QueryInterface of self instead of wrapped object.\n");\r
-        HRESULT hr = this->QueryInterface(riid, ppvObject);\r
-        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-        if (SUCCEEDED(hr))\r
-        {\r
-            WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);\r
-            return hr;\r
-        }\r
-        else\r
-        {\r
-            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");\r
-        }\r
-    }\r
-    else\r
-    {\r
-        WrapLogMsg("SID not identified.\n");\r
-    }\r
-    HRESULT hr = m_IServiceProvider->QueryService(guidService, riid, ppvObject);\r
-    if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-    WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-\r
-// *** IMenuPopup methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::Popup(POINTL *ppt=%p, RECTL *prcExclude=%p, MP_POPUPFLAGS dwFlags=%08x)\n", this, ppt, prcExclude, dwFlags);\r
-    HRESULT hr = m_IMenuPopup->Popup(ppt, prcExclude, dwFlags);\r
-    WrapLogExit("CMenuBandWrap::Popup() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::OnSelect(DWORD dwSelectType)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::OnSelect(DWORD dwSelectType=%08x)\n", this, dwSelectType);\r
-    HRESULT hr = m_IMenuPopup->OnSelect(dwSelectType);\r
-    WrapLogExit("CMenuBandWrap::OnSelect() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetSubMenu(IMenuPopup *pmp, BOOL fSet)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetSubMenu(IMenuPopup *pmp=%p, BOOL fSet=%d)\n", this, pmp, fSet);\r
-    HRESULT hr = m_IMenuPopup->SetSubMenu(pmp, fSet);\r
-    WrapLogExit("CMenuBandWrap::SetSubMenu() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-\r
-// *** IDeskBar methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetClient(IUnknown *punkClient)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetClient(IUnknown *punkClient=%p)\n", this, punkClient);\r
-    HRESULT hr = m_IDeskBar->SetClient(punkClient);\r
-    WrapLogExit("CMenuBandWrap::SetClient() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetClient(IUnknown **ppunkClient)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetClient(IUnknown **ppunkClient=%p)\n", this, ppunkClient);\r
-    HRESULT hr = m_IDeskBar->GetClient(ppunkClient);\r
-    if (ppunkClient) WrapLogMsg("*ppunkClient=%p\n", *ppunkClient);\r
-    WrapLogExit("CMenuBandWrap::GetClient() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::OnPosRectChangeDB(RECT *prc)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::OnPosRectChangeDB(RECT *prc=%p)\n", this, prc);\r
-    HRESULT hr = m_IDeskBar->OnPosRectChangeDB(prc);\r
-    if (prc) WrapLogMsg("*prc=%s\n", Wrap(*prc));\r
-    WrapLogExit("CMenuBandWrap::OnPosRectChangeDB() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-\r
-// *** IMenuBand methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsMenuMessage(MSG *pmsg)\r
-{\r
-    //WrapLogEnter("CMenuBandWrap<%p>::IsMenuMessage(MSG *pmsg=%p)\n", this, pmsg);\r
-    HRESULT hr = m_IMenuBand->IsMenuMessage(pmsg);\r
-    //WrapLogExit("CMenuBandWrap::IsMenuMessage() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::TranslateMenuMessage(MSG *pmsg, LRESULT *plRet)\r
-{\r
-    //WrapLogEnter("CMenuBandWrap<%p>::TranslateMenuMessage(MSG *pmsg=%p, LRESULT *plRet=%p)\n", this, pmsg, plRet);\r
-    HRESULT hr = m_IMenuBand->TranslateMenuMessage(pmsg, plRet);\r
-    //WrapLogExit("CMenuBandWrap::TranslateMenuMessage(*plRet=%d) = %08x\n", *plRet, hr);\r
-    return hr;\r
-}\r
-\r
-// *** IShellMenu methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::Initialize(IShellMenuCallback *psmc, UINT uId, UINT uIdAncestor, DWORD dwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::Initialize(IShellMenuCallback *psmc=%p, UINT uId=%u, UINT uIdAncestor=%u, DWORD dwFlags=%08x)\n", this, psmc, uId, uIdAncestor, dwFlags);\r
-    HRESULT hr = m_IShellMenu->Initialize(psmc, uId, uIdAncestor, dwFlags);\r
-    WrapLogExit("CMenuBandWrap::Initialize() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetMenuInfo(IShellMenuCallback **ppsmc, UINT *puId, UINT *puIdAncestor, DWORD *pdwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetMenuInfo(IShellMenuCallback **ppsmc=%p, UINT *puId=%p, UINT *puIdAncestor=%p, DWORD *pdwFlags=%p)\n", this, ppsmc, puId, puIdAncestor, pdwFlags);\r
-    HRESULT hr = m_IShellMenu->GetMenuInfo(ppsmc, puId, puIdAncestor, pdwFlags);\r
-    if (ppsmc) WrapLogMsg("*ppsmc=%p\n", *ppsmc);\r
-    if (puId) WrapLogMsg("*puId=%u\n", *puId);\r
-    if (puIdAncestor) WrapLogMsg("*puIdAncestor=%u\n", *puIdAncestor);\r
-    if (pdwFlags) WrapLogMsg("*pdwFlags=%08x\n", *pdwFlags);\r
-    WrapLogExit("CMenuBandWrap::GetMenuInfo() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetShellFolder(IShellFolder *psf, LPCITEMIDLIST pidlFolder, HKEY hKey, DWORD dwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetShellFolder(IShellFolder *psf=%p, LPCITEMIDLIST pidlFolder=%p, HKEY hKey=%p, DWORD dwFlags=%08x)\n", this, psf, pidlFolder, hKey, dwFlags);\r
-    HRESULT hr = m_IShellMenu->SetShellFolder(psf, pidlFolder, hKey, dwFlags);\r
-    WrapLogExit("CMenuBandWrap::SetShellFolder() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetShellFolder(DWORD *pdwFlags, LPITEMIDLIST *ppidl, REFIID riid, void **ppv)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetShellFolder(DWORD *pdwFlags=%p, LPITEMIDLIST *ppidl=%p, REFIID riid=%s, void **ppv=%p)\n", this, pdwFlags, ppidl, Wrap(riid), ppv);\r
-    HRESULT hr = m_IShellMenu->GetShellFolder(pdwFlags, ppidl, riid, ppv);\r
-    if (pdwFlags) WrapLogMsg("*pdwFlags=%08x\n", *pdwFlags);\r
-    if (ppidl) WrapLogMsg("*ppidl=%p\n", *ppidl);\r
-    if (ppv) WrapLogMsg("*ppv=%p\n", *ppv);\r
-    WrapLogExit("CMenuBandWrap::GetShellFolder() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetMenu(HMENU hmenu, HWND hwnd, DWORD dwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetMenu(HMENU hmenu=%p, HWND hwnd=%p, DWORD dwFlags=%08x)\n", this, hmenu, hwnd, dwFlags);\r
-    HRESULT hr = m_IShellMenu->SetMenu(hmenu, hwnd, dwFlags);\r
-    WrapLogExit("CMenuBandWrap::SetMenu() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetMenu(HMENU *phmenu, HWND *phwnd, DWORD *pdwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetMenu(HMENU *phmenu=%p, HWND *phwnd=%p, DWORD *pdwFlags=%p)\n", this, phmenu, phwnd, pdwFlags);\r
-    HRESULT hr = m_IShellMenu->GetMenu(phmenu, phwnd, pdwFlags);\r
-    if (phmenu) WrapLogMsg("*phmenu=%p\n", *phmenu);\r
-    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);\r
-    if (pdwFlags) WrapLogMsg("*pdwFlags=%08x\n", *pdwFlags);\r
-    WrapLogExit("CMenuBandWrap::GetMenu() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::InvalidateItem(LPSMDATA psmd, DWORD dwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::InvalidateItem(LPSMDATA psmd=%p, DWORD dwFlags=%08x)\n", this, psmd, dwFlags);\r
-    HRESULT hr = m_IShellMenu->InvalidateItem(psmd, dwFlags);\r
-    WrapLogExit("CMenuBandWrap::InvalidateItem() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetState(LPSMDATA psmd)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::GetState(LPSMDATA psmd=%p)\n", this, psmd);\r
-    HRESULT hr = m_IShellMenu->GetState(psmd);\r
-    WrapLogExit("CMenuBandWrap::GetState() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetMenuToolbar(IUnknown *punk, DWORD dwFlags)\r
-{\r
-    WrapLogEnter("CMenuBandWrap<%p>::SetMenuToolbar(IUnknown *punk=%p, DWORD dwFlags=%08x)\n", this, punk, dwFlags);\r
-    HRESULT hr = m_IShellMenu->SetMenuToolbar(punk, dwFlags);\r
-    WrapLogExit("CMenuBandWrap::SetMenuToolbar() = %08x\n", hr);\r
-    return hr;\r
-}\r
+/*
+* Shell Menu Band
+*
+* Copyright 2014 David Quintana
+*
+* 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 "precomp.h"
+#include "wraplog.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(CMenuBandWrap);
+
+class CMenuBandWrap :
+    public CComCoClass<CMenuBandWrap>,
+    public CComObjectRootEx<CComMultiThreadModelNoCS>,
+    public IDeskBand,
+    public IObjectWithSite,
+    public IInputObject,
+    public IPersistStream,
+    public IOleCommandTarget,
+    public IServiceProvider,
+    public IMenuPopup,
+    public IMenuBand,
+    public IShellMenu2,
+    public IWinEventHandler,
+    public IShellMenuAcc
+{
+public:
+    CMenuBandWrap() {}
+    ~CMenuBandWrap();
+
+    HRESULT InitWrap(IShellMenu * shellMenu);
+
+private:
+    CComPtr<IDeskBand         > m_IDeskBand;
+    CComPtr<IDockingWindow    > m_IDockingWindow;
+    CComPtr<IOleWindow        > m_IOleWindow;
+    CComPtr<IObjectWithSite   > m_IObjectWithSite;
+    CComPtr<IInputObject      > m_IInputObject;
+    CComPtr<IPersistStream    > m_IPersistStream;
+    CComPtr<IPersist          > m_IPersist;
+    CComPtr<IOleCommandTarget > m_IOleCommandTarget;
+    CComPtr<IServiceProvider  > m_IServiceProvider;
+    CComPtr<IMenuPopup        > m_IMenuPopup;
+    CComPtr<IDeskBar          > m_IDeskBar;
+    CComPtr<IMenuBand         > m_IMenuBand;
+    CComPtr<IShellMenu2       > m_IShellMenu2;
+    CComPtr<IShellMenu        > m_IShellMenu;
+    CComPtr<IWinEventHandler  > m_IWinEventHandler;
+    CComPtr<IShellMenuAcc     > m_IShellMenuAcc;
+    
+public:
+
+    // *** IDeskBand methods ***
+    virtual HRESULT STDMETHODCALLTYPE GetBandInfo(DWORD dwBandID, DWORD dwViewMode, DESKBANDINFO *pdbi);
+
+    // *** IDockingWindow methods ***
+    virtual HRESULT STDMETHODCALLTYPE ShowDW(BOOL fShow);
+    virtual HRESULT STDMETHODCALLTYPE CloseDW(DWORD dwReserved);
+    virtual HRESULT STDMETHODCALLTYPE ResizeBorderDW(LPCRECT prcBorder, IUnknown *punkToolbarSite, BOOL fReserved);
+
+    // *** IOleWindow methods ***
+    virtual HRESULT STDMETHODCALLTYPE GetWindow(HWND *phwnd);
+    virtual HRESULT STDMETHODCALLTYPE ContextSensitiveHelp(BOOL fEnterMode);
+
+    // *** IObjectWithSite methods ***
+    virtual HRESULT STDMETHODCALLTYPE SetSite(IUnknown *pUnkSite);
+    virtual HRESULT STDMETHODCALLTYPE GetSite(REFIID riid, PVOID *ppvSite);
+
+    // *** IInputObject methods ***
+    virtual HRESULT STDMETHODCALLTYPE UIActivateIO(BOOL fActivate, LPMSG lpMsg);
+    virtual HRESULT STDMETHODCALLTYPE HasFocusIO();
+    virtual HRESULT STDMETHODCALLTYPE TranslateAcceleratorIO(LPMSG lpMsg);
+
+    // *** IPersistStream methods ***
+    virtual HRESULT STDMETHODCALLTYPE IsDirty();
+    virtual HRESULT STDMETHODCALLTYPE Load(IStream *pStm);
+    virtual HRESULT STDMETHODCALLTYPE Save(IStream *pStm, BOOL fClearDirty);
+    virtual HRESULT STDMETHODCALLTYPE GetSizeMax(ULARGE_INTEGER *pcbSize);
+
+    // *** IPersist methods ***
+    virtual HRESULT STDMETHODCALLTYPE GetClassID(CLSID *pClassID);
+
+    // *** IOleCommandTarget methods ***
+    virtual HRESULT STDMETHODCALLTYPE QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText);
+    virtual HRESULT STDMETHODCALLTYPE Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut);
+
+    // *** IServiceProvider methods ***
+    virtual HRESULT STDMETHODCALLTYPE QueryService(REFGUID guidService, REFIID riid, void **ppvObject);
+
+    // *** IMenuPopup methods ***
+    virtual HRESULT STDMETHODCALLTYPE Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags);
+    virtual HRESULT STDMETHODCALLTYPE OnSelect(DWORD dwSelectType);
+    virtual HRESULT STDMETHODCALLTYPE SetSubMenu(IMenuPopup *pmp, BOOL fSet);
+
+    // *** IDeskBar methods ***
+    virtual HRESULT STDMETHODCALLTYPE SetClient(IUnknown *punkClient);
+    virtual HRESULT STDMETHODCALLTYPE GetClient(IUnknown **ppunkClient);
+    virtual HRESULT STDMETHODCALLTYPE OnPosRectChangeDB(RECT *prc);
+
+    // *** IMenuBand methods ***
+    virtual HRESULT STDMETHODCALLTYPE IsMenuMessage(MSG *pmsg);
+    virtual HRESULT STDMETHODCALLTYPE TranslateMenuMessage(MSG *pmsg, LRESULT *plRet);
+
+    // *** IShellMenu methods ***
+    virtual HRESULT STDMETHODCALLTYPE Initialize(IShellMenuCallback *psmc, UINT uId, UINT uIdAncestor, DWORD dwFlags);
+    virtual HRESULT STDMETHODCALLTYPE GetMenuInfo(IShellMenuCallback **ppsmc, UINT *puId, UINT *puIdAncestor, DWORD *pdwFlags);
+    virtual HRESULT STDMETHODCALLTYPE SetShellFolder(IShellFolder *psf, LPCITEMIDLIST pidlFolder, HKEY hKey, DWORD dwFlags);
+    virtual HRESULT STDMETHODCALLTYPE GetShellFolder(DWORD *pdwFlags, LPITEMIDLIST *ppidl, REFIID riid, void **ppv);
+    virtual HRESULT STDMETHODCALLTYPE SetMenu(HMENU hmenu, HWND hwnd, DWORD dwFlags);
+    virtual HRESULT STDMETHODCALLTYPE GetMenu(HMENU *phmenu, HWND *phwnd, DWORD *pdwFlags);
+    virtual HRESULT STDMETHODCALLTYPE InvalidateItem(LPSMDATA psmd, DWORD dwFlags);
+    virtual HRESULT STDMETHODCALLTYPE GetState(LPSMDATA psmd);
+    virtual HRESULT STDMETHODCALLTYPE SetMenuToolbar(IUnknown *punk, DWORD dwFlags);
+
+    // *** IWinEventHandler methods ***
+    virtual HRESULT STDMETHODCALLTYPE OnWinEvent(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *theResult);
+    virtual HRESULT STDMETHODCALLTYPE IsWindowOwner(HWND hWnd);
+
+    // *** IShellMenu2 methods ***
+    virtual HRESULT STDMETHODCALLTYPE GetSubMenu(THIS);
+    virtual HRESULT STDMETHODCALLTYPE SetToolbar(THIS);
+    virtual HRESULT STDMETHODCALLTYPE SetMinWidth(THIS);
+    virtual HRESULT STDMETHODCALLTYPE SetNoBorder(THIS);
+    virtual HRESULT STDMETHODCALLTYPE SetTheme(THIS);
+
+    // *** IShellMenuAcc methods ***
+    virtual HRESULT STDMETHODCALLTYPE GetTop(THIS);
+    virtual HRESULT STDMETHODCALLTYPE GetBottom(THIS);
+    virtual HRESULT STDMETHODCALLTYPE GetTracked(THIS);
+    virtual HRESULT STDMETHODCALLTYPE GetParentSite(THIS);
+    virtual HRESULT STDMETHODCALLTYPE GetState(THIS);
+    virtual HRESULT STDMETHODCALLTYPE DoDefaultAction(THIS);
+    virtual HRESULT STDMETHODCALLTYPE IsEmpty(THIS);
+
+    DECLARE_NOT_AGGREGATABLE(CMenuBandWrap)
+    DECLARE_PROTECT_FINAL_CONSTRUCT()
+
+    BEGIN_COM_MAP(CMenuBandWrap)
+        COM_INTERFACE_ENTRY_IID(IID_IDeskBar, IMenuPopup)
+        COM_INTERFACE_ENTRY_IID(IID_IShellMenu, IShellMenu)
+        COM_INTERFACE_ENTRY_IID(IID_IOleCommandTarget, IOleCommandTarget)
+        COM_INTERFACE_ENTRY_IID(IID_IOleWindow, IDeskBand)
+        COM_INTERFACE_ENTRY_IID(IID_IDockingWindow, IDockingWindow)
+        COM_INTERFACE_ENTRY_IID(IID_IDeskBand, IDeskBand)
+        COM_INTERFACE_ENTRY_IID(IID_IObjectWithSite, IObjectWithSite)
+        COM_INTERFACE_ENTRY_IID(IID_IInputObject, IInputObject)
+        COM_INTERFACE_ENTRY_IID(IID_IPersistStream, IPersistStream)
+        COM_INTERFACE_ENTRY_IID(IID_IPersist, IPersistStream)
+        COM_INTERFACE_ENTRY_IID(IID_IServiceProvider, IServiceProvider)
+        COM_INTERFACE_ENTRY_IID(IID_IMenuPopup, IMenuPopup)
+        COM_INTERFACE_ENTRY_IID(IID_IMenuBand, IMenuBand)
+        COM_INTERFACE_ENTRY_IID(IID_IShellMenu2, IShellMenu2)
+        COM_INTERFACE_ENTRY_IID(IID_IWinEventHandler, IWinEventHandler)
+        COM_INTERFACE_ENTRY_IID(IID_IShellMenuAcc, IShellMenuAcc)
+    END_COM_MAP()
+};
+
+extern "C"
+HRESULT CMenuBand_Wrapper(IShellMenu * shellMenu, REFIID riid, LPVOID *ppv)
+{
+    HRESULT hr;
+
+    *ppv = NULL;
+
+    CMenuBandWrap * site = new CComObject<CMenuBandWrap>();
+
+    if (!site)
+        return E_OUTOFMEMORY;
+
+    hr = site->InitWrap(shellMenu);
+    if (FAILED(hr))
+    {
+        site->Release();
+        return hr;
+    }
+
+    hr = site->QueryInterface(riid, ppv);
+
+    if (FAILED(hr))
+        site->Release();
+
+    return hr;
+}
+
+HRESULT CMenuBandWrap::InitWrap(IShellMenu * shellMenu)
+{
+    HRESULT hr;
+
+    WrapLogOpen();
+
+    m_IShellMenu = shellMenu;
+
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IDeskBand, &m_IDeskBand));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IDockingWindow, &m_IDockingWindow));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IOleWindow, &m_IOleWindow));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IObjectWithSite, &m_IObjectWithSite));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IInputObject, &m_IInputObject));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IPersistStream, &m_IPersistStream));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IPersist, &m_IPersist));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IOleCommandTarget, &m_IOleCommandTarget));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IServiceProvider, &m_IServiceProvider));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IMenuPopup, &m_IMenuPopup));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IDeskBar, &m_IDeskBar));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IMenuBand, &m_IMenuBand));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IShellMenu2, &m_IShellMenu2));
+    if (FAILED(hr)) return hr;
+    hr = shellMenu->QueryInterface(IID_PPV_ARG(IWinEventHandler, &m_IWinEventHandler));
+    if (FAILED(hr)) return hr;
+    //hr = shellMenu->QueryInterface(IID_PPV_ARG(IShellMenuAcc, &m_IShellMenuAcc));
+    m_IShellMenuAcc = NULL;
+    return hr;
+}
+
+CMenuBandWrap::~CMenuBandWrap()
+{
+    WrapLogClose();
+}
+
+
+// *** IShellMenu2 methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetSubMenu(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetSubMenu()\n", this);
+    HRESULT hr = m_IShellMenu2->GetSubMenu();
+    WrapLogExit("CMenuBandWrap::GetSubMenu() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetToolbar(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetToolbar()\n", this);
+    HRESULT hr = m_IShellMenu2->SetToolbar();
+    WrapLogExit("CMenuBandWrap::SetToolbar() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetMinWidth(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetMinWidth()\n", this);
+    HRESULT hr = m_IShellMenu2->SetMinWidth();
+    WrapLogExit("CMenuBandWrap::SetMinWidth() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetNoBorder(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetNoBorder()\n", this);
+    HRESULT hr = m_IShellMenu2->SetNoBorder();
+    WrapLogExit("CMenuBandWrap::SetNoBorder() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetTheme(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetTheme()\n", this);
+    HRESULT hr = m_IShellMenu2->SetTheme();
+    WrapLogExit("CMenuBandWrap::SetTheme() = %08x\n", hr);
+    return hr;
+}
+
+
+// *** IShellMenuAcc methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetTop(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetTop()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetTop();
+    WrapLogExit("CMenuBandWrap::GetTop() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetBottom(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetBottom();
+    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetTracked(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetBottom();
+    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetParentSite(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetBottom();
+    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetState(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetBottom();
+    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::DoDefaultAction(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetBottom();
+    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsEmpty(THIS)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBottom()\n", this);
+    HRESULT hr = m_IShellMenuAcc->GetBottom();
+    WrapLogExit("CMenuBandWrap::GetBottom() = %08x\n", hr);
+    return hr;
+}
+
+// *** IDeskBand methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetBandInfo(DWORD dwBandID, DWORD dwViewMode, DESKBANDINFO *pdbi)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetBandInfo(DWORD dwBandID=%d, DWORD dwViewMode=%d, DESKBANDINFO *pdbi=%p)\n", this, dwBandID, dwViewMode, pdbi);
+    HRESULT hr = m_IDeskBand->GetBandInfo(dwBandID, dwViewMode, pdbi);
+    WrapLogExit("CMenuBandWrap::GetBandInfo() = %08x\n", hr);
+    return hr;
+}
+
+// *** IDockingWindow methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::ShowDW(BOOL fShow)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::ShowDW(BOOL fShow=%d)\n", this, fShow);
+    HRESULT hr = m_IDockingWindow->ShowDW(fShow);
+    WrapLogExit("CMenuBandWrap::ShowDW() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::CloseDW(DWORD dwReserved)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::CloseDW(DWORD dwReserved=%d)\n", this, dwReserved);
+    HRESULT hr = m_IDockingWindow->CloseDW(dwReserved);
+    WrapLogExit("CMenuBandWrap::CloseDW() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::ResizeBorderDW(LPCRECT prcBorder, IUnknown *punkToolbarSite, BOOL fReserved)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::ResizeBorderDW(LPCRECT prcBorder=%p, IUnknown *punkToolbarSite=%p, BOOL fReserved=%d)\n", this, prcBorder, punkToolbarSite, fReserved);
+    if (prcBorder) WrapLogMsg("*prcBorder=%s\n", Wrap(*prcBorder));
+    HRESULT hr = m_IDockingWindow->ResizeBorderDW(prcBorder, punkToolbarSite, fReserved);
+    if (prcBorder) WrapLogMsg("*prcBorder=%s\n", Wrap(*prcBorder));
+    WrapLogExit("CMenuBandWrap::ResizeBorderDW() = %08x\n", hr);
+    return hr;
+}
+
+// *** IOleWindow methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetWindow(HWND *phwnd)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetWindow(HWND *phwnd=%p)\n", this, phwnd);
+    HRESULT hr = m_IOleWindow->GetWindow(phwnd);
+    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);
+    WrapLogExit("CMenuBandWrap::GetWindow() = %08x\n", hr);
+    return hr;
+}
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::ContextSensitiveHelp(BOOL fEnterMode)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::ContextSensitiveHelp(BOOL fEnterMode=%d)\n", this, fEnterMode);
+    HRESULT hr = m_IOleWindow->ContextSensitiveHelp(fEnterMode);
+    WrapLogExit("CMenuBandWrap::ContextSensitiveHelp() = %08x\n", hr);
+    return hr;
+}
+
+// *** IWinEventHandler methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::OnWinEvent(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *theResult)
+{
+    //WrapLogEnter("CMenuBandWrap<%p>::OnWinEvent(HWND hWnd=%p, UINT uMsg=%u, WPARAM wParam=%08x, LPARAM lParam=%08x, LRESULT *theResult=%p)\n", this, hWnd, uMsg, wParam, lParam, theResult);
+    HRESULT hr = m_IWinEventHandler->OnWinEvent(hWnd, uMsg, wParam, lParam, theResult);
+    //WrapLogExit("CMenuBandWrap::OnWinEvent() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsWindowOwner(HWND hWnd)
+{
+    //WrapLogEnter("CMenuBandWrap<%p>::IsWindowOwner(HWND hWnd=%08x)\n", this, hWnd);
+    HRESULT hr = m_IWinEventHandler->IsWindowOwner(hWnd);
+    //WrapLogExit("CMenuBandWrap::IsWindowOwner() = %08x\n", hr);
+    return hr;
+}
+
+// *** IObjectWithSite methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetSite(IUnknown *pUnkSite)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetSite(IUnknown *pUnkSite=%p)\n", this, pUnkSite);
+    HRESULT hr = m_IObjectWithSite->SetSite(pUnkSite);
+    WrapLogExit("CMenuBandWrap::SetSite() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetSite(REFIID riid, PVOID *ppvSite)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetSite(REFIID riid=%s, PVOID *ppvSite=%p)\n", this, Wrap(riid), ppvSite);
+    HRESULT hr = m_IObjectWithSite->GetSite(riid, ppvSite);
+    if (ppvSite) WrapLogMsg("*ppvSite=%p\n", *ppvSite);
+    WrapLogExit("CMenuBandWrap::GetSite() = %08x\n", hr);
+    return hr;
+}
+
+// *** IInputObject methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::UIActivateIO(BOOL fActivate, LPMSG lpMsg)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::UIActivateIO(BOOL fActivate=%d, LPMSG lpMsg=%p)\n", this, fActivate, lpMsg);
+    HRESULT hr = m_IInputObject->UIActivateIO(fActivate, lpMsg);
+    WrapLogExit("CMenuBandWrap::UIActivateIO() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::HasFocusIO()
+{
+    WrapLogEnter("CMenuBandWrap<%p>::HasFocusIO()\n", this);
+    HRESULT hr = m_IInputObject->HasFocusIO();
+    WrapLogExit("CMenuBandWrap::HasFocusIO() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::TranslateAcceleratorIO(LPMSG lpMsg)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::TranslateAcceleratorIO(LPMSG lpMsg=%p)\n", this, lpMsg);
+    if (lpMsg) WrapLogMsg("*lpMsg=%s\n", Wrap(*lpMsg));
+    HRESULT hr = m_IInputObject->TranslateAcceleratorIO(lpMsg);
+    WrapLogExit("CMenuBandWrap::TranslateAcceleratorIO() = %08x\n", hr);
+    return hr;
+}
+
+// *** IPersistStream methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsDirty()
+{
+    WrapLogEnter("CMenuBandWrap<%p>::IsDirty()\n", this);
+    HRESULT hr = m_IPersistStream->IsDirty();
+    WrapLogExit("CMenuBandWrap::IsDirty() = %08x\n", hr);
+    return hr;
+}
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::Load(IStream *pStm)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::Load(IStream *pStm=%p)\n", this, pStm);
+    HRESULT hr = m_IPersistStream->Load(pStm);
+    WrapLogExit("CMenuBandWrap::Load() = %08x\n", hr);
+    return hr;
+}
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::Save(IStream *pStm, BOOL fClearDirty)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::Save(IStream *pStm=%p, BOOL fClearDirty=%d)\n", this, pStm, fClearDirty);
+    HRESULT hr = m_IPersistStream->Save(pStm, fClearDirty);
+    WrapLogExit("CMenuBandWrap::Save() = %08x\n", hr);
+    return hr;
+}
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetSizeMax(ULARGE_INTEGER *pcbSize)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetSizeMax(ULARGE_INTEGER *pcbSize=%p)\n", this, pcbSize);
+    HRESULT hr = m_IPersistStream->GetSizeMax(pcbSize);
+    WrapLogExit("CMenuBandWrap::GetSizeMax() = %08x\n", hr);
+    return hr;
+}
+
+// *** IPersist methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetClassID(CLSID *pClassID)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetClassID(CLSID *pClassID=%p)\n", this, pClassID);
+    HRESULT hr = m_IPersist->GetClassID(pClassID);
+    if (pClassID) WrapLogMsg("*pClassID=%s\n", Wrap(*pClassID));
+    WrapLogExit("CMenuBandWrap::GetClassID() = %08x\n", hr);
+    return hr;
+}
+
+// *** IOleCommandTarget methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::QueryStatus(const GUID *pguidCmdGroup=%p, ULONG cCmds=%u, prgCmds=%p, pCmdText=%p)\n", this, pguidCmdGroup, cCmds, prgCmds, pCmdText);
+    HRESULT hr = m_IOleCommandTarget->QueryStatus(pguidCmdGroup, cCmds, prgCmds, pCmdText);
+    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));
+    WrapLogExit("CMenuBandWrap::QueryStatus() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::Exec(const GUID *pguidCmdGroup=%p, DWORD nCmdID=%d, DWORD nCmdexecopt=%d, VARIANT *pvaIn=%p, VARIANT *pvaOut=%p)\n", this, pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);
+    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));
+    HRESULT hr = m_IOleCommandTarget->Exec(pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);
+    WrapLogExit("CMenuBandWrap::Exec() = %08x\n", hr);
+    return hr;
+}
+
+// *** IServiceProvider methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::QueryService(REFGUID guidService, REFIID riid, void **ppvObject)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::QueryService(REFGUID guidService=%s, REFIID riid=%s, void **ppvObject=%p)\n", this, Wrap(guidService), Wrap(riid), ppvObject);
+
+    if (IsEqualIID(guidService, SID_SMenuBandChild))
+    {
+        WrapLogMsg("SID is SID_SMenuBandChild. Using QueryInterface of self instead of wrapped object.\n");
+        HRESULT hr = this->QueryInterface(riid, ppvObject);
+        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+        if (SUCCEEDED(hr))
+        {
+            WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);
+            return hr;
+        }
+        else
+        {
+            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");
+        }
+    }
+    else if (IsEqualIID(guidService, SID_SMenuBandBottom))
+    {
+        WrapLogMsg("SID is SID_SMenuBandBottom. Using QueryInterface of self instead of wrapped object.\n");
+        HRESULT hr = this->QueryInterface(riid, ppvObject);
+        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+        if (SUCCEEDED(hr))
+        {
+            WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);
+            return hr;
+        }
+        else
+        {
+            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");
+        }
+    }
+    else if (IsEqualIID(guidService, SID_SMenuBandBottomSelected))
+    {
+        WrapLogMsg("SID is SID_SMenuBandBottomSelected. Using QueryInterface of self instead of wrapped object.\n");
+        HRESULT hr = this->QueryInterface(riid, ppvObject);
+        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+        if (SUCCEEDED(hr))
+        {
+            WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);
+            return hr;
+        }
+        else
+        {
+            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");
+        }
+    }
+    else
+    {
+        WrapLogMsg("SID not identified.\n");
+    }
+    HRESULT hr = m_IServiceProvider->QueryService(guidService, riid, ppvObject);
+    if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+    WrapLogExit("CMenuBandWrap::QueryService() = %08x\n", hr);
+    return hr;
+}
+
+
+// *** IMenuPopup methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::Popup(POINTL *ppt=%p, RECTL *prcExclude=%p, MP_POPUPFLAGS dwFlags=%08x)\n", this, ppt, prcExclude, dwFlags);
+    HRESULT hr = m_IMenuPopup->Popup(ppt, prcExclude, dwFlags);
+    WrapLogExit("CMenuBandWrap::Popup() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::OnSelect(DWORD dwSelectType)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::OnSelect(DWORD dwSelectType=%08x)\n", this, dwSelectType);
+    HRESULT hr = m_IMenuPopup->OnSelect(dwSelectType);
+    WrapLogExit("CMenuBandWrap::OnSelect() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetSubMenu(IMenuPopup *pmp, BOOL fSet)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetSubMenu(IMenuPopup *pmp=%p, BOOL fSet=%d)\n", this, pmp, fSet);
+    HRESULT hr = m_IMenuPopup->SetSubMenu(pmp, fSet);
+    WrapLogExit("CMenuBandWrap::SetSubMenu() = %08x\n", hr);
+    return hr;
+}
+
+
+// *** IDeskBar methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetClient(IUnknown *punkClient)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetClient(IUnknown *punkClient=%p)\n", this, punkClient);
+    HRESULT hr = m_IDeskBar->SetClient(punkClient);
+    WrapLogExit("CMenuBandWrap::SetClient() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetClient(IUnknown **ppunkClient)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetClient(IUnknown **ppunkClient=%p)\n", this, ppunkClient);
+    HRESULT hr = m_IDeskBar->GetClient(ppunkClient);
+    if (ppunkClient) WrapLogMsg("*ppunkClient=%p\n", *ppunkClient);
+    WrapLogExit("CMenuBandWrap::GetClient() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::OnPosRectChangeDB(RECT *prc)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::OnPosRectChangeDB(RECT *prc=%p)\n", this, prc);
+    HRESULT hr = m_IDeskBar->OnPosRectChangeDB(prc);
+    if (prc) WrapLogMsg("*prc=%s\n", Wrap(*prc));
+    WrapLogExit("CMenuBandWrap::OnPosRectChangeDB() = %08x\n", hr);
+    return hr;
+}
+
+
+// *** IMenuBand methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::IsMenuMessage(MSG *pmsg)
+{
+    //WrapLogEnter("CMenuBandWrap<%p>::IsMenuMessage(MSG *pmsg=%p)\n", this, pmsg);
+    HRESULT hr = m_IMenuBand->IsMenuMessage(pmsg);
+    //WrapLogExit("CMenuBandWrap::IsMenuMessage() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::TranslateMenuMessage(MSG *pmsg, LRESULT *plRet)
+{
+    //WrapLogEnter("CMenuBandWrap<%p>::TranslateMenuMessage(MSG *pmsg=%p, LRESULT *plRet=%p)\n", this, pmsg, plRet);
+    HRESULT hr = m_IMenuBand->TranslateMenuMessage(pmsg, plRet);
+    //WrapLogExit("CMenuBandWrap::TranslateMenuMessage(*plRet=%d) = %08x\n", *plRet, hr);
+    return hr;
+}
+
+// *** IShellMenu methods ***
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::Initialize(IShellMenuCallback *psmc, UINT uId, UINT uIdAncestor, DWORD dwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::Initialize(IShellMenuCallback *psmc=%p, UINT uId=%u, UINT uIdAncestor=%u, DWORD dwFlags=%08x)\n", this, psmc, uId, uIdAncestor, dwFlags);
+    HRESULT hr = m_IShellMenu->Initialize(psmc, uId, uIdAncestor, dwFlags);
+    WrapLogExit("CMenuBandWrap::Initialize() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetMenuInfo(IShellMenuCallback **ppsmc, UINT *puId, UINT *puIdAncestor, DWORD *pdwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetMenuInfo(IShellMenuCallback **ppsmc=%p, UINT *puId=%p, UINT *puIdAncestor=%p, DWORD *pdwFlags=%p)\n", this, ppsmc, puId, puIdAncestor, pdwFlags);
+    HRESULT hr = m_IShellMenu->GetMenuInfo(ppsmc, puId, puIdAncestor, pdwFlags);
+    if (ppsmc) WrapLogMsg("*ppsmc=%p\n", *ppsmc);
+    if (puId) WrapLogMsg("*puId=%u\n", *puId);
+    if (puIdAncestor) WrapLogMsg("*puIdAncestor=%u\n", *puIdAncestor);
+    if (pdwFlags) WrapLogMsg("*pdwFlags=%08x\n", *pdwFlags);
+    WrapLogExit("CMenuBandWrap::GetMenuInfo() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetShellFolder(IShellFolder *psf, LPCITEMIDLIST pidlFolder, HKEY hKey, DWORD dwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetShellFolder(IShellFolder *psf=%p, LPCITEMIDLIST pidlFolder=%p, HKEY hKey=%p, DWORD dwFlags=%08x)\n", this, psf, pidlFolder, hKey, dwFlags);
+    HRESULT hr = m_IShellMenu->SetShellFolder(psf, pidlFolder, hKey, dwFlags);
+    WrapLogExit("CMenuBandWrap::SetShellFolder() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetShellFolder(DWORD *pdwFlags, LPITEMIDLIST *ppidl, REFIID riid, void **ppv)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetShellFolder(DWORD *pdwFlags=%p, LPITEMIDLIST *ppidl=%p, REFIID riid=%s, void **ppv=%p)\n", this, pdwFlags, ppidl, Wrap(riid), ppv);
+    HRESULT hr = m_IShellMenu->GetShellFolder(pdwFlags, ppidl, riid, ppv);
+    if (pdwFlags) WrapLogMsg("*pdwFlags=%08x\n", *pdwFlags);
+    if (ppidl) WrapLogMsg("*ppidl=%p\n", *ppidl);
+    if (ppv) WrapLogMsg("*ppv=%p\n", *ppv);
+    WrapLogExit("CMenuBandWrap::GetShellFolder() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetMenu(HMENU hmenu, HWND hwnd, DWORD dwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetMenu(HMENU hmenu=%p, HWND hwnd=%p, DWORD dwFlags=%08x)\n", this, hmenu, hwnd, dwFlags);
+    HRESULT hr = m_IShellMenu->SetMenu(hmenu, hwnd, dwFlags);
+    WrapLogExit("CMenuBandWrap::SetMenu() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetMenu(HMENU *phmenu, HWND *phwnd, DWORD *pdwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetMenu(HMENU *phmenu=%p, HWND *phwnd=%p, DWORD *pdwFlags=%p)\n", this, phmenu, phwnd, pdwFlags);
+    HRESULT hr = m_IShellMenu->GetMenu(phmenu, phwnd, pdwFlags);
+    if (phmenu) WrapLogMsg("*phmenu=%p\n", *phmenu);
+    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);
+    if (pdwFlags) WrapLogMsg("*pdwFlags=%08x\n", *pdwFlags);
+    WrapLogExit("CMenuBandWrap::GetMenu() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::InvalidateItem(LPSMDATA psmd, DWORD dwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::InvalidateItem(LPSMDATA psmd=%p, DWORD dwFlags=%08x)\n", this, psmd, dwFlags);
+    HRESULT hr = m_IShellMenu->InvalidateItem(psmd, dwFlags);
+    WrapLogExit("CMenuBandWrap::InvalidateItem() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::GetState(LPSMDATA psmd)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::GetState(LPSMDATA psmd=%p)\n", this, psmd);
+    HRESULT hr = m_IShellMenu->GetState(psmd);
+    WrapLogExit("CMenuBandWrap::GetState() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuBandWrap::SetMenuToolbar(IUnknown *punk, DWORD dwFlags)
+{
+    WrapLogEnter("CMenuBandWrap<%p>::SetMenuToolbar(IUnknown *punk=%p, DWORD dwFlags=%08x)\n", this, punk, dwFlags);
+    HRESULT hr = m_IShellMenu->SetMenuToolbar(punk, dwFlags);
+    WrapLogExit("CMenuBandWrap::SetMenuToolbar() = %08x\n", hr);
+    return hr;
+}
index ced8e22..f71ff94 100644 (file)
-/*\r
-* Shell Menu Desk Bar\r
-*\r
-* Copyright 2014 David Quintana\r
-*\r
-* This library is free software; you can redistribute it and/or\r
-* modify it under the terms of the GNU Lesser General Public\r
-* License as published by the Free Software Foundation; either\r
-* version 2.1 of the License, or (at your option) any later version.\r
-*\r
-* This library is distributed in the hope that it will be useful,\r
-* but WITHOUT ANY WARRANTY; without even the implied warranty of\r
-* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU\r
-* Lesser General Public License for more details.\r
-*\r
-* You should have received a copy of the GNU Lesser General Public\r
-* License along with this library; if not, write to the Free Software\r
-* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA\r
-*/\r
-#include "precomp.h"\r
-#include "wraplog.h"\r
-\r
-class CMenuDeskBarWrap :\r
-    public CComCoClass<CMenuDeskBarWrap>,\r
-    public CComObjectRootEx<CComMultiThreadModelNoCS>,\r
-    public IOleCommandTarget,\r
-    public IServiceProvider,\r
-    public IInputObjectSite,\r
-    public IInputObject,\r
-    public IMenuPopup,\r
-    public IObjectWithSite,\r
-    public IBanneredBar,\r
-    public IInitializeObject\r
-{\r
-public:\r
-    CMenuDeskBarWrap();\r
-    ~CMenuDeskBarWrap();\r
-\r
-private:\r
-    IUnknown * m_IUnknown;\r
-    IMenuPopup * m_IMenuPopup;\r
-    IOleCommandTarget * m_IOleCommandTarget;\r
-    IServiceProvider * m_IServiceProvider;\r
-    IDeskBar * m_IDeskBar;\r
-    IOleWindow * m_IOleWindow;\r
-    IInputObjectSite * m_IInputObjectSite;\r
-    IInputObject * m_IInputObject;\r
-    IObjectWithSite * m_IObjectWithSite;\r
-    IBanneredBar * m_IBanneredBar;\r
-    IInitializeObject * m_IInitializeObject;\r
-\r
-public:\r
-    // *** IMenuPopup methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags);\r
-    virtual HRESULT STDMETHODCALLTYPE OnSelect(DWORD dwSelectType);\r
-    virtual HRESULT STDMETHODCALLTYPE SetSubMenu(IMenuPopup *pmp, BOOL fSet);\r
-\r
-    // *** IOleWindow methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE GetWindow(HWND *phwnd);\r
-    virtual HRESULT STDMETHODCALLTYPE ContextSensitiveHelp(BOOL fEnterMode);\r
-\r
-    // *** IObjectWithSite methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE SetSite(IUnknown *pUnkSite);\r
-    virtual HRESULT STDMETHODCALLTYPE GetSite(REFIID riid, PVOID *ppvSite);\r
-\r
-    // *** IBanneredBar methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE SetIconSize(DWORD iIcon);\r
-    virtual HRESULT STDMETHODCALLTYPE GetIconSize(DWORD* piIcon);\r
-    virtual HRESULT STDMETHODCALLTYPE SetBitmap(HBITMAP hBitmap);\r
-    virtual HRESULT STDMETHODCALLTYPE GetBitmap(HBITMAP* phBitmap);\r
-\r
-    // *** IInitializeObject methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE Initialize(THIS);\r
-\r
-    // *** IOleCommandTarget methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText);\r
-    virtual HRESULT STDMETHODCALLTYPE Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut);\r
-\r
-    // *** IServiceProvider methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE QueryService(REFGUID guidService, REFIID riid, void **ppvObject);\r
-\r
-    // *** IInputObjectSite methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE OnFocusChangeIS(LPUNKNOWN lpUnknown, BOOL bFocus);\r
-\r
-    // *** IInputObject methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE UIActivateIO(BOOL bActivating, LPMSG lpMsg);\r
-    virtual HRESULT STDMETHODCALLTYPE HasFocusIO(THIS);\r
-    virtual HRESULT STDMETHODCALLTYPE TranslateAcceleratorIO(LPMSG lpMsg);\r
-\r
-    // *** IDeskBar methods ***\r
-    virtual HRESULT STDMETHODCALLTYPE SetClient(IUnknown *punkClient);\r
-    virtual HRESULT STDMETHODCALLTYPE GetClient(IUnknown **ppunkClient);\r
-    virtual HRESULT STDMETHODCALLTYPE OnPosRectChangeDB(LPRECT prc);\r
-\r
-    DECLARE_NOT_AGGREGATABLE(CMenuDeskBarWrap)\r
-    DECLARE_PROTECT_FINAL_CONSTRUCT()\r
-\r
-    BEGIN_COM_MAP(CMenuDeskBarWrap)\r
-        COM_INTERFACE_ENTRY_IID(IID_IMenuPopup, IMenuPopup)\r
-        COM_INTERFACE_ENTRY_IID(IID_IOleCommandTarget, IOleCommandTarget)\r
-        COM_INTERFACE_ENTRY_IID(IID_IServiceProvider, IServiceProvider)\r
-        COM_INTERFACE_ENTRY_IID(IID_IInputObjectSite, IInputObjectSite)\r
-        COM_INTERFACE_ENTRY_IID(IID_IInputObject, IInputObject)\r
-        COM_INTERFACE_ENTRY_IID(IID_IDeskBar, IMenuPopup)\r
-        COM_INTERFACE_ENTRY_IID(IID_IOleWindow, IMenuPopup)\r
-        COM_INTERFACE_ENTRY_IID(IID_IObjectWithSite, IObjectWithSite)\r
-        COM_INTERFACE_ENTRY_IID(IID_IBanneredBar, IBanneredBar)\r
-        COM_INTERFACE_ENTRY_IID(IID_IInitializeObject, IInitializeObject)\r
-    END_COM_MAP()\r
-};\r
-\r
-extern "C"\r
-HRESULT CMenuDeskBar_Wrapper(REFIID riid, LPVOID *ppv)\r
-{\r
-    *ppv = NULL;\r
-\r
-    CMenuDeskBarWrap * deskbar = new CComObject<CMenuDeskBarWrap>();\r
-\r
-    if (!deskbar)\r
-        return E_OUTOFMEMORY;\r
-\r
-    HRESULT hr = deskbar->QueryInterface(riid, ppv);\r
-\r
-    if (FAILED(hr))\r
-        deskbar->Release();\r
-\r
-    return hr;\r
-}\r
-\r
-CMenuDeskBarWrap::CMenuDeskBarWrap()\r
-{\r
-    WrapLogOpen();\r
-\r
-    CoCreateInstance(CLSID_MenuDeskBar, NULL, CLSCTX_INPROC_SERVER, IID_PPV_ARG(IMenuPopup, &m_IMenuPopup));\r
-    m_IMenuPopup->QueryInterface(IID_PPV_ARG(IUnknown, &m_IUnknown));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IOleCommandTarget, &m_IOleCommandTarget));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IServiceProvider, &m_IServiceProvider));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IDeskBar, &m_IDeskBar));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IOleWindow, &m_IOleWindow));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IInputObjectSite, &m_IInputObjectSite));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IInputObject, &m_IInputObject));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IObjectWithSite, &m_IObjectWithSite));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IBanneredBar, &m_IBanneredBar));\r
-    m_IUnknown->QueryInterface(IID_PPV_ARG(IInitializeObject, &m_IInitializeObject));\r
-}\r
-\r
-CMenuDeskBarWrap::~CMenuDeskBarWrap()\r
-{\r
-    m_IUnknown->Release();\r
-    m_IMenuPopup->Release();\r
-    m_IOleCommandTarget->Release();\r
-    m_IServiceProvider->Release();\r
-    m_IDeskBar->Release();\r
-    m_IOleWindow->Release();\r
-    m_IInputObjectSite->Release();\r
-    m_IInputObject->Release();\r
-    m_IObjectWithSite->Release();\r
-    m_IBanneredBar->Release();\r
-    m_IInitializeObject->Release();\r
-\r
-    WrapLogClose();\r
-}\r
-\r
-// *** IMenuPopup methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::Popup(POINTL *ppt=%p, RECTL *prcExclude=%p, MP_POPUPFLAGS dwFlags=%08x)\n", this, ppt, prcExclude, dwFlags);\r
-    HRESULT hr = m_IMenuPopup->Popup(ppt, prcExclude, dwFlags);\r
-    WrapLogExit("CMenuDeskBarWrap::Popup() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::OnSelect(DWORD dwSelectType)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::OnSelect(DWORD dwSelectType=%08x)\n", this, dwSelectType);\r
-    HRESULT hr = m_IMenuPopup->OnSelect(dwSelectType);\r
-    WrapLogExit("CMenuDeskBarWrap::OnSelect() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetSubMenu(IMenuPopup *pmp, BOOL fSet)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::SetSubMenu(IMenuPopup *pmp=%p, BOOL fSet=%d)\n", this, pmp, fSet);\r
-    HRESULT hr = m_IMenuPopup->SetSubMenu(pmp, fSet);\r
-    WrapLogExit("CMenuDeskBarWrap::SetSubMenu() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IOleWindow methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetWindow(HWND *phwnd)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::GetWindow(HWND *phwnd=%p)\n", this, phwnd);\r
-    HRESULT hr = m_IOleWindow->GetWindow(phwnd);\r
-    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);\r
-    WrapLogExit("CMenuDeskBarWrap::GetWindow() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::ContextSensitiveHelp(BOOL fEnterMode)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::ContextSensitiveHelp(BOOL fEnterMode=%d)\n", this, fEnterMode);\r
-    HRESULT hr = m_IOleWindow->ContextSensitiveHelp(fEnterMode);\r
-    WrapLogExit("CMenuDeskBarWrap::ContextSensitiveHelp() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IObjectWithSite methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetSite(IUnknown *pUnkSite)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::SetSite(IUnknown *pUnkSite=%p)\n", this, pUnkSite);\r
-    HRESULT hr = m_IObjectWithSite->SetSite(pUnkSite);\r
-    WrapLogExit("CMenuDeskBarWrap::SetSite() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetSite(REFIID riid, PVOID *ppvSite)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::GetSite(REFIID riid=%s, PVOID *ppvSite=%p)\n", this, Wrap(riid), ppvSite);\r
-    HRESULT hr = m_IObjectWithSite->GetSite(riid, ppvSite);\r
-    if (ppvSite) WrapLogMsg("*ppvSite=%p\n", *ppvSite);\r
-    WrapLogExit("CMenuDeskBarWrap::GetSite() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IBanneredBar methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetIconSize(DWORD iIcon)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::SetIconSize(DWORD iIcon=%d)\n", this, iIcon);\r
-    HRESULT hr = m_IBanneredBar->SetIconSize(iIcon);\r
-    WrapLogExit("CMenuDeskBarWrap::SetIconSize() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetIconSize(DWORD* piIcon)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::GetIconSize(DWORD* piIcon=%p)\n", this, piIcon);\r
-    HRESULT hr = m_IBanneredBar->GetIconSize(piIcon);\r
-    if (piIcon) WrapLogMsg("*piIcon=%d\n", *piIcon);\r
-    WrapLogExit("CMenuDeskBarWrap::GetIconSize() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetBitmap(HBITMAP hBitmap)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::SetBitmap(HBITMAP hBitmap=%p)\n", this, hBitmap);\r
-    HRESULT hr = m_IBanneredBar->SetBitmap(hBitmap);\r
-    WrapLogExit("CMenuDeskBarWrap::SetBitmap() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetBitmap(HBITMAP* phBitmap)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::GetBitmap(HBITMAP* phBitmap=%p)\n", this, phBitmap);\r
-    HRESULT hr = m_IBanneredBar->GetBitmap(phBitmap);\r
-    if (phBitmap) WrapLogMsg("*phBitmap=%p\n", *phBitmap);\r
-    WrapLogExit("CMenuDeskBarWrap::GetBitmap() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-\r
-// *** IInitializeObject methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::Initialize(THIS)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::Initialize()\n", this);\r
-    HRESULT hr = m_IInitializeObject->Initialize();\r
-    WrapLogExit("CMenuDeskBarWrap::Initialize() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IOleCommandTarget methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::QueryStatus(const GUID *pguidCmdGroup=%p, ULONG cCmds=%u, prgCmds=%p, pCmdText=%p)\n", this, pguidCmdGroup, cCmds, prgCmds, pCmdText);\r
-    HRESULT hr = m_IOleCommandTarget->QueryStatus(pguidCmdGroup, cCmds, prgCmds, pCmdText);\r
-    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));\r
-    WrapLogExit("CMenuDeskBarWrap::QueryStatus() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::Exec(const GUID *pguidCmdGroup=%p, DWORD nCmdID=%d, DWORD nCmdexecopt=%d, VARIANT *pvaIn=%p, VARIANT *pvaOut=%p)\n", this, pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);\r
-    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));\r
-    HRESULT hr = m_IOleCommandTarget->Exec(pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);\r
-    WrapLogExit("CMenuDeskBarWrap::Exec() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IServiceProvider methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::QueryService(REFGUID guidService, REFIID riid, void **ppvObject)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::QueryService(REFGUID guidService=%s, REFIID riid=%s, void **ppvObject=%p)\n", this, Wrap(guidService), Wrap(riid), ppvObject);\r
-\r
-    if (IsEqualIID(guidService, SID_SMenuPopup))\r
-    {\r
-        WrapLogMsg("SID is SID_SMenuPopup. Using QueryInterface of self instead of wrapped object.\n");\r
-        HRESULT hr = this->QueryInterface(riid, ppvObject);\r
-        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-        if (SUCCEEDED(hr))\r
-        {\r
-            WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);\r
-            return hr;\r
-        }\r
-        else\r
-        {\r
-            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");\r
-        }\r
-    }\r
-    else if (IsEqualIID(guidService, SID_SMenuBandParent))\r
-    {\r
-        WrapLogMsg("SID is SID_SMenuBandParent. Using QueryInterface of self instead of wrapped object.\n");\r
-        HRESULT hr = this->QueryInterface(riid, ppvObject);\r
-        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-        if (SUCCEEDED(hr))\r
-        {\r
-            WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);\r
-            return hr;\r
-        }\r
-        else\r
-        {\r
-            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");\r
-        }\r
-    }\r
-    else if (IsEqualIID(guidService, SID_STopLevelBrowser))\r
-    {\r
-        WrapLogMsg("SID is SID_STopLevelBrowser. Using QueryInterface of self instead of wrapped object.\n");\r
-        HRESULT hr = this->QueryInterface(riid, ppvObject);\r
-        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-        if (SUCCEEDED(hr))\r
-        {\r
-            WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);\r
-            return hr;\r
-        }\r
-        else\r
-        {\r
-            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");\r
-        }\r
-    }\r
-    else\r
-    {\r
-        WrapLogMsg("SID not identified. Calling wrapped object's QueryService.\n");\r
-    }\r
-    HRESULT hr = m_IServiceProvider->QueryService(guidService, riid, ppvObject);\r
-    if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);\r
-    WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IInputObjectSite methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::OnFocusChangeIS(LPUNKNOWN lpUnknown, BOOL bFocus)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::OnFocusChangeIS(LPUNKNOWN lpUnknown=%p, BOOL bFocus=%d)\n", this, lpUnknown, bFocus);\r
-    HRESULT hr = m_IInputObjectSite->OnFocusChangeIS(lpUnknown, bFocus);\r
-    WrapLogExit("CMenuDeskBarWrap::OnFocusChangeIS() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IInputObject methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::UIActivateIO(BOOL bActivating, LPMSG lpMsg)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::UIActivateIO(BOOL bActivating=%d, LPMSG lpMsg=%p)\n", this, bActivating, lpMsg);\r
-    HRESULT hr = m_IInputObject->UIActivateIO(bActivating, lpMsg);\r
-    WrapLogExit("CMenuDeskBarWrap::UIActivateIO() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::HasFocusIO(THIS)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::HasFocusIO()\n", this);\r
-    HRESULT hr = m_IInputObject->HasFocusIO();\r
-    WrapLogExit("CMenuDeskBarWrap::HasFocusIO() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::TranslateAcceleratorIO(LPMSG lpMsg)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::TranslateAcceleratorIO(LPMSG lpMsg=%p)\n", this, lpMsg);\r
-    if (lpMsg) WrapLogMsg("*lpMsg=%s\n", Wrap(*lpMsg));\r
-    HRESULT hr = m_IInputObject->TranslateAcceleratorIO(lpMsg);\r
-    WrapLogExit("CMenuDeskBarWrap::TranslateAcceleratorIO() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-// *** IDeskBar methods ***\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetClient(IUnknown *punkClient)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::SetClient(IUnknown *punkClient=%p)\n", this, punkClient);\r
-    HRESULT hr = m_IDeskBar->SetClient(punkClient);\r
-    WrapLogExit("CMenuDeskBarWrap::SetClient() = %08x\n", hr);\r
-\r
-    CComPtr<IDeskBarClient> dbc;\r
-    punkClient->QueryInterface(IID_PPV_ARG(IDeskBarClient, &dbc));\r
-    dbc->SetDeskBarSite(static_cast<IDeskBar*>(this));\r
-\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetClient(IUnknown **ppunkClient)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::GetClient(IUnknown **ppunkClient=%p)\n", this, ppunkClient);\r
-    HRESULT hr = m_IDeskBar->GetClient(ppunkClient);\r
-    if (ppunkClient) WrapLogMsg("*ppunkClient=%p\n", *ppunkClient);\r
-    WrapLogExit("CMenuDeskBarWrap::GetClient() = %08x\n", hr);\r
-    return hr;\r
-}\r
-\r
-HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::OnPosRectChangeDB(LPRECT prc)\r
-{\r
-    WrapLogEnter("CMenuDeskBarWrap<%p>::OnPosRectChangeDB(RECT *prc=%p)\n", this, prc);\r
-    HRESULT hr = m_IDeskBar->OnPosRectChangeDB(prc);\r
-    if (prc) WrapLogMsg("*prc=%s\n", Wrap(*prc));\r
-    WrapLogExit("CMenuDeskBarWrap::OnPosRectChangeDB() = %08x\n", hr);\r
-    return hr;\r
-}\r
+/*
+* Shell Menu Desk Bar
+*
+* Copyright 2014 David Quintana
+*
+* 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 "precomp.h"
+#include "wraplog.h"
+
+class CMenuDeskBarWrap :
+    public CComCoClass<CMenuDeskBarWrap>,
+    public CComObjectRootEx<CComMultiThreadModelNoCS>,
+    public IOleCommandTarget,
+    public IServiceProvider,
+    public IInputObjectSite,
+    public IInputObject,
+    public IMenuPopup,
+    public IObjectWithSite,
+    public IBanneredBar,
+    public IInitializeObject
+{
+public:
+    CMenuDeskBarWrap() {}
+    ~CMenuDeskBarWrap();
+
+    HRESULT InitWrap(IDeskBar * shellMenu);
+
+private:
+    CComPtr<IMenuPopup        > m_IMenuPopup;
+    CComPtr<IOleCommandTarget > m_IOleCommandTarget;
+    CComPtr<IServiceProvider  > m_IServiceProvider;
+    CComPtr<IDeskBar          > m_IDeskBar;
+    CComPtr<IOleWindow        > m_IOleWindow;
+    CComPtr<IInputObjectSite  > m_IInputObjectSite;
+    CComPtr<IInputObject      > m_IInputObject;
+    CComPtr<IObjectWithSite   > m_IObjectWithSite;
+    CComPtr<IBanneredBar      > m_IBanneredBar;
+    CComPtr<IInitializeObject > m_IInitializeObject;
+
+public:
+    // *** IMenuPopup methods ***
+    virtual HRESULT STDMETHODCALLTYPE Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags);
+    virtual HRESULT STDMETHODCALLTYPE OnSelect(DWORD dwSelectType);
+    virtual HRESULT STDMETHODCALLTYPE SetSubMenu(IMenuPopup *pmp, BOOL fSet);
+
+    // *** IOleWindow methods ***
+    virtual HRESULT STDMETHODCALLTYPE GetWindow(HWND *phwnd);
+    virtual HRESULT STDMETHODCALLTYPE ContextSensitiveHelp(BOOL fEnterMode);
+
+    // *** IObjectWithSite methods ***
+    virtual HRESULT STDMETHODCALLTYPE SetSite(IUnknown *pUnkSite);
+    virtual HRESULT STDMETHODCALLTYPE GetSite(REFIID riid, PVOID *ppvSite);
+
+    // *** IBanneredBar methods ***
+    virtual HRESULT STDMETHODCALLTYPE SetIconSize(DWORD iIcon);
+    virtual HRESULT STDMETHODCALLTYPE GetIconSize(DWORD* piIcon);
+    virtual HRESULT STDMETHODCALLTYPE SetBitmap(HBITMAP hBitmap);
+    virtual HRESULT STDMETHODCALLTYPE GetBitmap(HBITMAP* phBitmap);
+
+    // *** IInitializeObject methods ***
+    virtual HRESULT STDMETHODCALLTYPE Initialize(THIS);
+
+    // *** IOleCommandTarget methods ***
+    virtual HRESULT STDMETHODCALLTYPE QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText);
+    virtual HRESULT STDMETHODCALLTYPE Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut);
+
+    // *** IServiceProvider methods ***
+    virtual HRESULT STDMETHODCALLTYPE QueryService(REFGUID guidService, REFIID riid, void **ppvObject);
+
+    // *** IInputObjectSite methods ***
+    virtual HRESULT STDMETHODCALLTYPE OnFocusChangeIS(LPUNKNOWN lpUnknown, BOOL bFocus);
+
+    // *** IInputObject methods ***
+    virtual HRESULT STDMETHODCALLTYPE UIActivateIO(BOOL bActivating, LPMSG lpMsg);
+    virtual HRESULT STDMETHODCALLTYPE HasFocusIO(THIS);
+    virtual HRESULT STDMETHODCALLTYPE TranslateAcceleratorIO(LPMSG lpMsg);
+
+    // *** IDeskBar methods ***
+    virtual HRESULT STDMETHODCALLTYPE SetClient(IUnknown *punkClient);
+    virtual HRESULT STDMETHODCALLTYPE GetClient(IUnknown **ppunkClient);
+    virtual HRESULT STDMETHODCALLTYPE OnPosRectChangeDB(LPRECT prc);
+
+    DECLARE_NOT_AGGREGATABLE(CMenuDeskBarWrap)
+    DECLARE_PROTECT_FINAL_CONSTRUCT()
+
+    BEGIN_COM_MAP(CMenuDeskBarWrap)
+        COM_INTERFACE_ENTRY_IID(IID_IMenuPopup, IMenuPopup)
+        COM_INTERFACE_ENTRY_IID(IID_IOleCommandTarget, IOleCommandTarget)
+        COM_INTERFACE_ENTRY_IID(IID_IServiceProvider, IServiceProvider)
+        COM_INTERFACE_ENTRY_IID(IID_IInputObjectSite, IInputObjectSite)
+        COM_INTERFACE_ENTRY_IID(IID_IInputObject, IInputObject)
+        COM_INTERFACE_ENTRY_IID(IID_IDeskBar, IMenuPopup)
+        COM_INTERFACE_ENTRY_IID(IID_IOleWindow, IMenuPopup)
+        COM_INTERFACE_ENTRY_IID(IID_IObjectWithSite, IObjectWithSite)
+        COM_INTERFACE_ENTRY_IID(IID_IBanneredBar, IBanneredBar)
+        COM_INTERFACE_ENTRY_IID(IID_IInitializeObject, IInitializeObject)
+    END_COM_MAP()
+};
+
+extern "C"
+HRESULT CMenuDeskBar_Wrapper(IDeskBar * deskBar, REFIID riid, LPVOID *ppv)
+{
+    HRESULT hr;
+
+    *ppv = NULL;
+
+    CMenuDeskBarWrap * bar = new CComObject<CMenuDeskBarWrap>();
+    if (!bar)
+        return E_OUTOFMEMORY;
+
+    hr = bar->InitWrap(deskBar);
+    if (FAILED(hr))
+    {
+        bar->Release();
+        return hr;
+    }
+
+    hr = bar->QueryInterface(riid, ppv);
+
+    if (FAILED(hr))
+        bar->Release();
+
+    return hr;
+}
+
+HRESULT CMenuDeskBarWrap::InitWrap(IDeskBar * deskBar)
+{
+    HRESULT hr;
+
+    WrapLogOpen();
+
+    m_IDeskBar = deskBar;
+
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IOleCommandTarget, &m_IOleCommandTarget));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IServiceProvider, &m_IServiceProvider));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IMenuPopup, &m_IMenuPopup));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IOleWindow, &m_IOleWindow));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IInputObjectSite, &m_IInputObjectSite));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IInputObject, &m_IInputObject));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IObjectWithSite, &m_IObjectWithSite));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IBanneredBar, &m_IBanneredBar));
+    if (FAILED(hr)) return hr;
+    hr = deskBar->QueryInterface(IID_PPV_ARG(IInitializeObject, &m_IInitializeObject));
+    return hr;
+}
+
+CMenuDeskBarWrap::~CMenuDeskBarWrap()
+{
+    WrapLogClose();
+}
+
+// *** IMenuPopup methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::Popup(POINTL *ppt=%p, RECTL *prcExclude=%p, MP_POPUPFLAGS dwFlags=%08x)\n", this, ppt, prcExclude, dwFlags);
+    HRESULT hr = m_IMenuPopup->Popup(ppt, prcExclude, dwFlags);
+    WrapLogExit("CMenuDeskBarWrap::Popup() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::OnSelect(DWORD dwSelectType)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::OnSelect(DWORD dwSelectType=%08x)\n", this, dwSelectType);
+    HRESULT hr = m_IMenuPopup->OnSelect(dwSelectType);
+    WrapLogExit("CMenuDeskBarWrap::OnSelect() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetSubMenu(IMenuPopup *pmp, BOOL fSet)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::SetSubMenu(IMenuPopup *pmp=%p, BOOL fSet=%d)\n", this, pmp, fSet);
+    HRESULT hr = m_IMenuPopup->SetSubMenu(pmp, fSet);
+    WrapLogExit("CMenuDeskBarWrap::SetSubMenu() = %08x\n", hr);
+    return hr;
+}
+
+// *** IOleWindow methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetWindow(HWND *phwnd)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::GetWindow(HWND *phwnd=%p)\n", this, phwnd);
+    HRESULT hr = m_IOleWindow->GetWindow(phwnd);
+    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);
+    WrapLogExit("CMenuDeskBarWrap::GetWindow() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::ContextSensitiveHelp(BOOL fEnterMode)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::ContextSensitiveHelp(BOOL fEnterMode=%d)\n", this, fEnterMode);
+    HRESULT hr = m_IOleWindow->ContextSensitiveHelp(fEnterMode);
+    WrapLogExit("CMenuDeskBarWrap::ContextSensitiveHelp() = %08x\n", hr);
+    return hr;
+}
+
+// *** IObjectWithSite methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetSite(IUnknown *pUnkSite)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::SetSite(IUnknown *pUnkSite=%p)\n", this, pUnkSite);
+    HRESULT hr = m_IObjectWithSite->SetSite(pUnkSite);
+    WrapLogExit("CMenuDeskBarWrap::SetSite() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetSite(REFIID riid, PVOID *ppvSite)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::GetSite(REFIID riid=%s, PVOID *ppvSite=%p)\n", this, Wrap(riid), ppvSite);
+    HRESULT hr = m_IObjectWithSite->GetSite(riid, ppvSite);
+    if (ppvSite) WrapLogMsg("*ppvSite=%p\n", *ppvSite);
+    WrapLogExit("CMenuDeskBarWrap::GetSite() = %08x\n", hr);
+    return hr;
+}
+
+// *** IBanneredBar methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetIconSize(DWORD iIcon)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::SetIconSize(DWORD iIcon=%d)\n", this, iIcon);
+    HRESULT hr = m_IBanneredBar->SetIconSize(iIcon);
+    WrapLogExit("CMenuDeskBarWrap::SetIconSize() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetIconSize(DWORD* piIcon)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::GetIconSize(DWORD* piIcon=%p)\n", this, piIcon);
+    HRESULT hr = m_IBanneredBar->GetIconSize(piIcon);
+    if (piIcon) WrapLogMsg("*piIcon=%d\n", *piIcon);
+    WrapLogExit("CMenuDeskBarWrap::GetIconSize() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetBitmap(HBITMAP hBitmap)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::SetBitmap(HBITMAP hBitmap=%p)\n", this, hBitmap);
+    HRESULT hr = m_IBanneredBar->SetBitmap(hBitmap);
+    WrapLogExit("CMenuDeskBarWrap::SetBitmap() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetBitmap(HBITMAP* phBitmap)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::GetBitmap(HBITMAP* phBitmap=%p)\n", this, phBitmap);
+    HRESULT hr = m_IBanneredBar->GetBitmap(phBitmap);
+    if (phBitmap) WrapLogMsg("*phBitmap=%p\n", *phBitmap);
+    WrapLogExit("CMenuDeskBarWrap::GetBitmap() = %08x\n", hr);
+    return hr;
+}
+
+
+// *** IInitializeObject methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::Initialize(THIS)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::Initialize()\n", this);
+    HRESULT hr = m_IInitializeObject->Initialize();
+    WrapLogExit("CMenuDeskBarWrap::Initialize() = %08x\n", hr);
+    return hr;
+}
+
+// *** IOleCommandTarget methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::QueryStatus(const GUID *pguidCmdGroup=%p, ULONG cCmds=%u, prgCmds=%p, pCmdText=%p)\n", this, pguidCmdGroup, cCmds, prgCmds, pCmdText);
+    HRESULT hr = m_IOleCommandTarget->QueryStatus(pguidCmdGroup, cCmds, prgCmds, pCmdText);
+    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));
+    WrapLogExit("CMenuDeskBarWrap::QueryStatus() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::Exec(const GUID *pguidCmdGroup=%p, DWORD nCmdID=%d, DWORD nCmdexecopt=%d, VARIANT *pvaIn=%p, VARIANT *pvaOut=%p)\n", this, pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);
+    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));
+    HRESULT hr = m_IOleCommandTarget->Exec(pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);
+    WrapLogExit("CMenuDeskBarWrap::Exec() = %08x\n", hr);
+    return hr;
+}
+
+// *** IServiceProvider methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::QueryService(REFGUID guidService, REFIID riid, void **ppvObject)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::QueryService(REFGUID guidService=%s, REFIID riid=%s, void **ppvObject=%p)\n", this, Wrap(guidService), Wrap(riid), ppvObject);
+
+    if (IsEqualIID(guidService, SID_SMenuPopup))
+    {
+        WrapLogMsg("SID is SID_SMenuPopup. Using QueryInterface of self instead of wrapped object.\n");
+        HRESULT hr = this->QueryInterface(riid, ppvObject);
+        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+        if (SUCCEEDED(hr))
+        {
+            WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);
+            return hr;
+        }
+        else
+        {
+            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");
+        }
+    }
+    else if (IsEqualIID(guidService, SID_SMenuBandParent))
+    {
+        WrapLogMsg("SID is SID_SMenuBandParent. Using QueryInterface of self instead of wrapped object.\n");
+        HRESULT hr = this->QueryInterface(riid, ppvObject);
+        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+        if (SUCCEEDED(hr))
+        {
+            WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);
+            return hr;
+        }
+        else
+        {
+            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");
+        }
+    }
+    else if (IsEqualIID(guidService, SID_STopLevelBrowser))
+    {
+        WrapLogMsg("SID is SID_STopLevelBrowser. Using QueryInterface of self instead of wrapped object.\n");
+        HRESULT hr = this->QueryInterface(riid, ppvObject);
+        if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+        if (SUCCEEDED(hr))
+        {
+            WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);
+            return hr;
+        }
+        else
+        {
+            WrapLogMsg("QueryInterface on wrapper failed. Handing over to innter object.\n");
+        }
+    }
+    else
+    {
+        WrapLogMsg("SID not identified. Calling wrapped object's QueryService.\n");
+    }
+    HRESULT hr = m_IServiceProvider->QueryService(guidService, riid, ppvObject);
+    if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+    WrapLogExit("CMenuDeskBarWrap::QueryService() = %08x\n", hr);
+    return hr;
+}
+
+// *** IInputObjectSite methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::OnFocusChangeIS(LPUNKNOWN lpUnknown, BOOL bFocus)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::OnFocusChangeIS(LPUNKNOWN lpUnknown=%p, BOOL bFocus=%d)\n", this, lpUnknown, bFocus);
+    HRESULT hr = m_IInputObjectSite->OnFocusChangeIS(lpUnknown, bFocus);
+    WrapLogExit("CMenuDeskBarWrap::OnFocusChangeIS() = %08x\n", hr);
+    return hr;
+}
+
+// *** IInputObject methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::UIActivateIO(BOOL bActivating, LPMSG lpMsg)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::UIActivateIO(BOOL bActivating=%d, LPMSG lpMsg=%p)\n", this, bActivating, lpMsg);
+    HRESULT hr = m_IInputObject->UIActivateIO(bActivating, lpMsg);
+    WrapLogExit("CMenuDeskBarWrap::UIActivateIO() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::HasFocusIO(THIS)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::HasFocusIO()\n", this);
+    HRESULT hr = m_IInputObject->HasFocusIO();
+    WrapLogExit("CMenuDeskBarWrap::HasFocusIO() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::TranslateAcceleratorIO(LPMSG lpMsg)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::TranslateAcceleratorIO(LPMSG lpMsg=%p)\n", this, lpMsg);
+    if (lpMsg) WrapLogMsg("*lpMsg=%s\n", Wrap(*lpMsg));
+    HRESULT hr = m_IInputObject->TranslateAcceleratorIO(lpMsg);
+    WrapLogExit("CMenuDeskBarWrap::TranslateAcceleratorIO() = %08x\n", hr);
+    return hr;
+}
+
+// *** IDeskBar methods ***
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::SetClient(IUnknown *punkClient)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::SetClient(IUnknown *punkClient=%p)\n", this, punkClient);
+    HRESULT hr = m_IDeskBar->SetClient(punkClient);
+    WrapLogExit("CMenuDeskBarWrap::SetClient() = %08x\n", hr);
+
+    CComPtr<IDeskBarClient> dbc;
+    punkClient->QueryInterface(IID_PPV_ARG(IDeskBarClient, &dbc));
+    dbc->SetDeskBarSite(static_cast<IDeskBar*>(this));
+
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::GetClient(IUnknown **ppunkClient)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::GetClient(IUnknown **ppunkClient=%p)\n", this, ppunkClient);
+    HRESULT hr = m_IDeskBar->GetClient(ppunkClient);
+    if (ppunkClient) WrapLogMsg("*ppunkClient=%p\n", *ppunkClient);
+    WrapLogExit("CMenuDeskBarWrap::GetClient() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuDeskBarWrap::OnPosRectChangeDB(LPRECT prc)
+{
+    WrapLogEnter("CMenuDeskBarWrap<%p>::OnPosRectChangeDB(RECT *prc=%p)\n", this, prc);
+    HRESULT hr = m_IDeskBar->OnPosRectChangeDB(prc);
+    if (prc) WrapLogMsg("*prc=%s\n", Wrap(*prc));
+    WrapLogExit("CMenuDeskBarWrap::OnPosRectChangeDB() = %08x\n", hr);
+    return hr;
+}
diff --git a/base/shell/rshell/logging/CMenuSiteWrap.cpp b/base/shell/rshell/logging/CMenuSiteWrap.cpp
new file mode 100644 (file)
index 0000000..61e3d3d
--- /dev/null
@@ -0,0 +1,366 @@
+/*
+ * Shell Menu Site
+ *
+ * Copyright 2014 David Quintana
+ *
+ * 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 "precomp.h"
+#include "wraplog.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(menusite);
+
+class CMenuSiteWrap :
+    public CComCoClass<CMenuSiteWrap>,
+    public CComObjectRootEx<CComMultiThreadModelNoCS>,
+    public IBandSite,
+    public IDeskBarClient,
+    public IOleCommandTarget,
+    public IInputObject,
+    public IInputObjectSite,
+    public IWinEventHandler,
+    public IServiceProvider
+{
+public:
+    CMenuSiteWrap() {}
+    ~CMenuSiteWrap();
+
+    HRESULT InitWrap(IBandSite * bandSite);
+
+private:
+    CComPtr<IBandSite        > m_IBandSite;
+    CComPtr<IDeskBarClient   > m_IDeskBarClient;
+    CComPtr<IOleWindow       > m_IOleWindow;
+    CComPtr<IOleCommandTarget> m_IOleCommandTarget;
+    CComPtr<IInputObject     > m_IInputObject;
+    CComPtr<IInputObjectSite > m_IInputObjectSite;
+    CComPtr<IWinEventHandler > m_IWinEventHandler;
+    CComPtr<IServiceProvider > m_IServiceProvider;
+
+public:
+    // IBandSite
+    virtual HRESULT STDMETHODCALLTYPE AddBand(IUnknown * punk);
+    virtual HRESULT STDMETHODCALLTYPE EnumBands(UINT uBand, DWORD* pdwBandID);
+    virtual HRESULT STDMETHODCALLTYPE QueryBand(DWORD dwBandID, IDeskBand **ppstb, DWORD *pdwState, LPWSTR pszName, int cchName);
+    virtual HRESULT STDMETHODCALLTYPE GetBandObject(DWORD dwBandID, REFIID riid, VOID **ppv);
+    virtual HRESULT STDMETHODCALLTYPE GetBandSiteInfo(BANDSITEINFO *pbsinfo);
+    virtual HRESULT STDMETHODCALLTYPE RemoveBand(DWORD dwBandID);
+    virtual HRESULT STDMETHODCALLTYPE SetBandSiteInfo(const BANDSITEINFO *pbsinfo);
+    virtual HRESULT STDMETHODCALLTYPE SetBandState(DWORD dwBandID, DWORD dwMask, DWORD dwState);
+
+    // IDeskBarClient
+    virtual HRESULT STDMETHODCALLTYPE SetDeskBarSite(IUnknown *punkSite);
+    virtual HRESULT STDMETHODCALLTYPE SetModeDBC(DWORD dwMode);
+    virtual HRESULT STDMETHODCALLTYPE GetSize(DWORD dwWhich, LPRECT prc);
+    virtual HRESULT STDMETHODCALLTYPE UIActivateDBC(DWORD dwState);
+
+    // IOleWindow
+    virtual HRESULT STDMETHODCALLTYPE GetWindow(HWND *phwnd);
+    virtual HRESULT STDMETHODCALLTYPE ContextSensitiveHelp(BOOL fEnterMode);
+
+    // IOleCommandTarget
+    virtual HRESULT STDMETHODCALLTYPE QueryStatus(const GUID * pguidCmdGroup, ULONG cCmds, OLECMD prgCmds [], OLECMDTEXT *pCmdText);
+    virtual HRESULT STDMETHODCALLTYPE Exec(const GUID * pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut);
+
+    // IInputObject
+    virtual HRESULT STDMETHODCALLTYPE UIActivateIO(BOOL fActivate, LPMSG lpMsg);
+    virtual HRESULT STDMETHODCALLTYPE HasFocusIO();
+    virtual HRESULT STDMETHODCALLTYPE TranslateAcceleratorIO(LPMSG lpMsg);
+
+    // IInputObjectSite
+    virtual HRESULT STDMETHODCALLTYPE OnFocusChangeIS(IUnknown *punkObj, BOOL fSetFocus);
+
+    // IWinEventHandler
+    virtual HRESULT STDMETHODCALLTYPE IsWindowOwner(HWND hWnd);
+    virtual HRESULT STDMETHODCALLTYPE OnWinEvent(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *theResult);
+
+    // IServiceProvider
+    virtual HRESULT STDMETHODCALLTYPE QueryService(REFGUID guidService, REFIID riid, void **ppvObject);
+
+    DECLARE_NOT_AGGREGATABLE(CMenuSiteWrap)
+    DECLARE_PROTECT_FINAL_CONSTRUCT()
+    BEGIN_COM_MAP(CMenuSiteWrap)
+        COM_INTERFACE_ENTRY_IID(IID_IBandSite, IBandSite)
+        COM_INTERFACE_ENTRY_IID(IID_IDeskBarClient, IDeskBarClient)
+        COM_INTERFACE_ENTRY_IID(IID_IOleWindow, IOleWindow)
+        COM_INTERFACE_ENTRY_IID(IID_IOleCommandTarget, IOleCommandTarget)
+        COM_INTERFACE_ENTRY_IID(IID_IInputObject, IInputObject)
+        COM_INTERFACE_ENTRY_IID(IID_IInputObjectSite, IInputObjectSite)
+        COM_INTERFACE_ENTRY_IID(IID_IWinEventHandler, IWinEventHandler)
+        COM_INTERFACE_ENTRY_IID(IID_IServiceProvider, IServiceProvider)
+    END_COM_MAP()
+};
+
+extern "C"
+HRESULT CMenuSite_Wrapper(IBandSite * bandSite, REFIID riid, LPVOID *ppv)
+{
+    HRESULT hr;
+
+    *ppv = NULL;
+
+    CMenuSiteWrap * site = new CComObject<CMenuSiteWrap>();
+
+    if (!site)
+        return E_OUTOFMEMORY;
+
+    hr = site->InitWrap(bandSite);
+    if (FAILED(hr))
+    {
+        site->Release();
+        return hr;
+    }
+
+    hr = site->QueryInterface(riid, ppv);
+
+    if (FAILED(hr))
+        site->Release();
+
+    return hr;
+}
+
+HRESULT CMenuSiteWrap::InitWrap(IBandSite * bandSite)
+{
+    HRESULT hr;
+
+    WrapLogOpen();
+
+    m_IBandSite = bandSite;
+
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IDeskBarClient, &m_IDeskBarClient));
+    if (FAILED(hr)) return hr;
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IOleWindow, &m_IOleWindow));
+    if (FAILED(hr)) return hr;
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IOleCommandTarget, &m_IOleCommandTarget));
+    if (FAILED(hr)) return hr;
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IInputObject, &m_IInputObject));
+    if (FAILED(hr)) return hr;
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IInputObjectSite, &m_IInputObjectSite));
+    if (FAILED(hr)) return hr;
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IWinEventHandler, &m_IWinEventHandler));
+    if (FAILED(hr)) return hr;
+    hr = bandSite->QueryInterface(IID_PPV_ARG(IServiceProvider, &m_IServiceProvider));
+    return hr;
+}
+
+CMenuSiteWrap::~CMenuSiteWrap()
+{
+    WrapLogClose();
+}
+
+// IBandSite
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::AddBand(IUnknown * punk)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::AddBand(IUnknown * punk=%p)\n", this, punk);
+    HRESULT hr = m_IBandSite->AddBand(punk);
+    WrapLogExit("CMenuSiteWrap::AddBand() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::EnumBands(UINT uBand, DWORD* pdwBandID)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::EnumBands(UINT uBand=%u, DWORD* pdwBandID=%p)\n", this, uBand, pdwBandID);
+    HRESULT hr = m_IBandSite->EnumBands(uBand, pdwBandID);
+    if (pdwBandID) WrapLogMsg("*pdwBandID=%d\n", *pdwBandID);
+    WrapLogExit("CMenuSiteWrap::EnumBands() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::QueryBand(DWORD dwBandID, IDeskBand **ppstb, DWORD *pdwState, LPWSTR pszName, int cchName)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::QueryBand(DWORD dwBandID=%d, IDeskBand **ppstb=%p, DWORD *pdwState=%p, LPWSTR pszName=%p, int cchName=%p)\n", this, dwBandID, ppstb, pdwState, pszName, cchName);
+    HRESULT hr = m_IBandSite->QueryBand(dwBandID, ppstb, pdwState, pszName, cchName);
+    if (ppstb) WrapLogMsg("*ppstb=%p\n", *ppstb);
+    if (pdwState) WrapLogMsg("*pdwState=%d\n", *pdwState);
+    WrapLogExit("CMenuSiteWrap::QueryBand() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::GetBandObject(DWORD dwBandID, REFIID riid, VOID **ppv)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::GetBandObject(DWORD dwBandID, REFIID riid, VOID **ppv)\n", this, dwBandID, riid, ppv);
+    HRESULT hr = m_IBandSite->GetBandObject(dwBandID, riid, ppv);
+    if (ppv) WrapLogMsg("*ppv=%p\n", *ppv);
+    WrapLogExit("CMenuSiteWrap::GetBandObject() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::GetBandSiteInfo(BANDSITEINFO *pbsinfo)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::GetBandSiteInfo(BANDSITEINFO *pbsinfo=%p)\n", this, pbsinfo);
+    HRESULT hr = m_IBandSite->GetBandSiteInfo(pbsinfo);
+    if (pbsinfo) WrapLogMsg("*pbsinfo=%p\n", *pbsinfo);
+    WrapLogExit("CMenuSiteWrap::GetBandSiteInfo() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::RemoveBand(DWORD dwBandID)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::RemoveBand(DWORD dwBandID=%d)\n", this, dwBandID);
+    HRESULT hr = m_IBandSite->RemoveBand(dwBandID);
+    WrapLogExit("CMenuSiteWrap::RemoveBand() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::SetBandSiteInfo(const BANDSITEINFO *pbsinfo)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::SetBandSiteInfo(const BANDSITEINFO *pbsinfo=%p)\n", this, pbsinfo);
+    //if (phwnd) WrapLogMsg("*pbsinfo=%s\n", Wrap(*pbsinfo));
+    HRESULT hr = m_IBandSite->SetBandSiteInfo(pbsinfo);
+    WrapLogExit("CMenuSiteWrap::SetBandSiteInfo() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::SetBandState(DWORD dwBandID, DWORD dwMask, DWORD dwState)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::SetBandState(DWORD dwBandID=%d, DWORD dwMask=%08x, DWORD dwState=%d)\n", this, dwBandID, dwMask, dwState);
+    HRESULT hr = m_IBandSite->SetBandState(dwBandID, dwMask, dwState);
+    WrapLogExit("CMenuSiteWrap::SetBandState() = %08x\n", hr);
+    return hr;
+}
+
+// *** IDeskBarClient ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::SetDeskBarSite(IUnknown *punkSite)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::SetDeskBarSite(IUnknown *punkSite=%p)\n", this, punkSite);
+    HRESULT hr = m_IDeskBarClient->SetDeskBarSite(punkSite);
+    if (punkSite) WrapLogMsg("*punkSite=%p\n", *punkSite);
+    WrapLogExit("CMenuSiteWrap::SetDeskBarSite() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::SetModeDBC(DWORD dwMode)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::SetModeDBC(DWORD dwMode=%d)\n", this, dwMode);
+    HRESULT hr = m_IDeskBarClient->SetModeDBC(dwMode);
+    WrapLogExit("CMenuSiteWrap::SetModeDBC() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::GetSize(DWORD dwWhich, LPRECT prc)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::GetSize(DWORD dwWhich=%d, LPRECT prc=%p)\n", this, dwWhich, prc);
+    HRESULT hr = m_IDeskBarClient->GetSize(dwWhich, prc);
+    if (prc) WrapLogMsg("*prc=%s\n", Wrap(*prc));
+    WrapLogExit("CMenuSiteWrap::GetSize() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::UIActivateDBC(DWORD dwState)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::UIActivateDBC(DWORD dwState=%d)\n", this, dwState);
+    HRESULT hr = m_IDeskBarClient->UIActivateDBC(dwState);
+    WrapLogExit("CMenuSiteWrap::UIActivateDBC() = %08x\n", hr);
+    return hr;
+}
+
+// *** IOleWindow methods ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::GetWindow(HWND *phwnd)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::GetWindow(HWND *phwnd=%p)\n", this, phwnd);
+    HRESULT hr = m_IOleWindow->GetWindow(phwnd);
+    if (phwnd) WrapLogMsg("*phwnd=%p\n", *phwnd);
+    WrapLogExit("CMenuSiteWrap::GetWindow() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::ContextSensitiveHelp(BOOL fEnterMode)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::ContextSensitiveHelp(BOOL fEnterMode=%d)\n", this, fEnterMode);
+    HRESULT hr = m_IOleWindow->ContextSensitiveHelp(fEnterMode);
+    WrapLogExit("CMenuSiteWrap::ContextSensitiveHelp() = %08x\n", hr);
+    return hr;
+}
+
+// *** IOleCommandTarget methods ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, OLECMD prgCmds[], OLECMDTEXT *pCmdText)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::QueryStatus(const GUID *pguidCmdGroup=%p, ULONG cCmds=%u, prgCmds=%p, pCmdText=%p)\n", this, pguidCmdGroup, cCmds, prgCmds, pCmdText);
+    HRESULT hr = m_IOleCommandTarget->QueryStatus(pguidCmdGroup, cCmds, prgCmds, pCmdText);
+    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));
+    WrapLogExit("CMenuSiteWrap::QueryStatus() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::Exec(const GUID *pguidCmdGroup, DWORD nCmdID, DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::Exec(const GUID *pguidCmdGroup=%p, DWORD nCmdID=%d, DWORD nCmdexecopt=%d, VARIANT *pvaIn=%p, VARIANT *pvaOut=%p)\n", this, pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);
+    if (pguidCmdGroup) WrapLogMsg("*pguidCmdGroup=%s\n", Wrap(*pguidCmdGroup));
+    HRESULT hr = m_IOleCommandTarget->Exec(pguidCmdGroup, nCmdID, nCmdexecopt, pvaIn, pvaOut);
+    WrapLogExit("CMenuSiteWrap::Exec() = %08x\n", hr);
+    return hr;
+}
+
+// *** IInputObject methods ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::UIActivateIO(BOOL fActivate, LPMSG lpMsg)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::UIActivateIO(BOOL fActivate=%d, LPMSG lpMsg=%p)\n", this, fActivate, lpMsg);
+    HRESULT hr = m_IInputObject->UIActivateIO(fActivate, lpMsg);
+    WrapLogExit("CMenuSiteWrap::UIActivateIO() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::HasFocusIO()
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::HasFocusIO()\n", this);
+    HRESULT hr = m_IInputObject->HasFocusIO();
+    WrapLogExit("CMenuSiteWrap::HasFocusIO() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::TranslateAcceleratorIO(LPMSG lpMsg)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::TranslateAcceleratorIO(LPMSG lpMsg=%p)\n", this, lpMsg);
+    if (lpMsg) WrapLogMsg("*lpMsg=%s\n", Wrap(*lpMsg));
+    HRESULT hr = m_IInputObject->TranslateAcceleratorIO(lpMsg);
+    WrapLogExit("CMenuSiteWrap::TranslateAcceleratorIO() = %08x\n", hr);
+    return hr;
+}
+
+// *** IInputObjectSite methods ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::OnFocusChangeIS(LPUNKNOWN lpUnknown, BOOL bFocus)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::OnFocusChangeIS(LPUNKNOWN lpUnknown=%p, BOOL bFocus=%d)\n", this, lpUnknown, bFocus);
+    HRESULT hr = m_IInputObjectSite->OnFocusChangeIS(lpUnknown, bFocus);
+    WrapLogExit("CMenuSiteWrap::OnFocusChangeIS() = %08x\n", hr);
+    return hr;
+}
+
+// *** IWinEventHandler methods ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::OnWinEvent(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT *theResult)
+{
+    //WrapLogEnter("CMenuSiteWrap<%p>::OnWinEvent(HWND hWnd=%p, UINT uMsg=%u, WPARAM wParam=%08x, LPARAM lParam=%08x, LRESULT *theResult=%p)\n", this, hWnd, uMsg, wParam, lParam, theResult);
+    HRESULT hr = m_IWinEventHandler->OnWinEvent(hWnd, uMsg, wParam, lParam, theResult);
+    //WrapLogExit("CMenuSiteWrap::OnWinEvent() = %08x\n", hr);
+    return hr;
+}
+
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::IsWindowOwner(HWND hWnd)
+{
+    //WrapLogEnter("CMenuSiteWrap<%p>::IsWindowOwner(HWND hWnd=%08x)\n", this, hWnd);
+    HRESULT hr = m_IWinEventHandler->IsWindowOwner(hWnd);
+    //WrapLogExit("CMenuSiteWrap::IsWindowOwner() = %08x\n", hr);
+    return hr;
+}
+
+// *** IServiceProvider methods ***
+HRESULT STDMETHODCALLTYPE CMenuSiteWrap::QueryService(REFGUID guidService, REFIID riid, void **ppvObject)
+{
+    WrapLogEnter("CMenuSiteWrap<%p>::QueryService(REFGUID guidService=%s, REFIID riid=%s, void **ppvObject=%p)\n", this, Wrap(guidService), Wrap(riid), ppvObject);
+    HRESULT hr = m_IServiceProvider->QueryService(guidService, riid, ppvObject);
+    if (ppvObject) WrapLogMsg("*ppvObject=%p\n", *ppvObject);
+    WrapLogExit("CMenuSiteWrap::QueryService() = %08x\n", hr);
+    return hr;
+}
index 0d58f2f..e7b1f14 100644 (file)
@@ -1,11 +1,11 @@
 
-#define USE_SYSTEM_MENUDESKBAR 0
+#define USE_SYSTEM_MENUDESKBAR 1
 #define USE_SYSTEM_MENUSITE 0
 #define USE_SYSTEM_MENUBAND 0
 
-// if not using system above
-#define WRAP_MENUDESKBAR 0
-#define WRAP_MENUBAND 0
+#define WRAP_MENUDESKBAR 1
+#define WRAP_MENUSITE 1
+#define WRAP_MENUBAND 1
 
 #include <stdio.h>
 #include <tchar.h>
@@ -38,8 +38,9 @@
 #define SMC_EXEC 4
 extern "C" INT WINAPI Shell_GetCachedImageIndex(LPCWSTR szPath, INT nIndex, UINT bSimulateDoc);
 
+extern "C" HRESULT CMenuDeskBar_Constructor(REFIID riid, LPVOID *ppv);
 extern "C" HRESULT CMenuSite_Constructor(REFIID riid, LPVOID *ppv);
 extern "C" HRESULT CMenuBand_Constructor(REFIID riid, LPVOID *ppv);
-extern "C" HRESULT CMenuDeskBar_Constructor(REFIID riid, LPVOID *ppv);
-extern "C" HRESULT CMenuBand_Wrapper(REFIID riid, LPVOID *ppv);
-extern "C" HRESULT CMenuDeskBar_Wrapper(REFIID riid, LPVOID *ppv);
+extern "C" HRESULT CMenuDeskBar_Wrapper(IDeskBar * db, REFIID riid, LPVOID *ppv);
+extern "C" HRESULT CMenuSite_Wrapper(IBandSite * bs, REFIID riid, LPVOID *ppv);
+extern "C" HRESULT CMenuBand_Wrapper(IShellMenu * sm, REFIID riid, LPVOID *ppv);
index d3903cf..7358941 100644 (file)
@@ -77,41 +77,51 @@ LPSTR Wrap(const T& value);
 template <>
 LPSTR Wrap<GUID>(REFGUID guid)
 {
-    LPSTR cGuid = strTemp[nTemps++];
-    StringCchPrintfA(cGuid, _countof(strTemp[0]),
+    LPSTR cStr = strTemp[nTemps++];
+    StringCchPrintfA(cStr, _countof(strTemp[0]),
         "{%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
         guid.Data1, guid.Data2, guid.Data3,
         guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3],
         guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]);
-    return cGuid;
+    return cStr;
 }
 
 template <>
 LPSTR Wrap<RECT>(const RECT& rect)
 {
-    LPSTR cGuid = strTemp[nTemps++];
-    StringCchPrintfA(cGuid, _countof(strTemp[0]),
+    LPSTR cStr = strTemp[nTemps++];
+    StringCchPrintfA(cStr, _countof(strTemp[0]),
         "{L: %d, T: %d, R: %d, B: %d}",
         rect.left, rect.top, rect.right, rect.bottom);
-    return cGuid;
+    return cStr;
 }
 
 template <>
 LPSTR Wrap<OLECMD>(const OLECMD& cmd)
 {
-    LPSTR cGuid = strTemp[nTemps++];
-    StringCchPrintfA(cGuid, _countof(strTemp[0]),
+    LPSTR cStr = strTemp[nTemps++];
+    StringCchPrintfA(cStr, _countof(strTemp[0]),
         "{ID: %d, F: %d}",
         cmd.cmdID, cmd.cmdf);
-    return cGuid;
+    return cStr;
 }
 
 template <>
 LPSTR Wrap<MSG>(const MSG& msg)
 {
-    LPSTR cGuid = strTemp[nTemps++];
-    StringCchPrintfA(cGuid, _countof(strTemp[0]),
+    LPSTR cStr = strTemp[nTemps++];
+    StringCchPrintfA(cStr, _countof(strTemp[0]),
         "{HWND: %d, Code: %d, W: %p, L: %p, T: %d, P.X: %d, P.Y: %d}",
         msg.hwnd, msg.message, msg.wParam, msg.lParam, msg.time, msg.pt.x, msg.pt.y);
-    return cGuid;
+    return cStr;
+}
+
+template <>
+LPSTR Wrap<BANDSITEINFO>(const BANDSITEINFO& bsi)
+{
+    LPSTR cStr = strTemp[nTemps++];
+    StringCchPrintfA(cStr, _countof(strTemp[0]),
+        "{dwMask: %08x, dwState: %08x, dwStyle: %08x}",
+        bsi.dwMask, bsi.dwState, bsi.dwStyle);
+    return cStr;
 }