mirror of
https://github.com/reactos/reactos.git
synced 2025-08-07 02:42:59 +00:00
[RSHELL]
* CMenuSite: Improve code style. svn path=/branches/shell-experiments/; revision=62212
This commit is contained in:
parent
c57c04a7c2
commit
e325d1372e
1 changed files with 51 additions and 118 deletions
|
@ -48,11 +48,11 @@ class CMenuSite :
|
||||||
public IWinEventHandler,
|
public IWinEventHandler,
|
||||||
public IServiceProvider
|
public IServiceProvider
|
||||||
{
|
{
|
||||||
IUnknown * m_DeskBarSite;
|
CComPtr<IUnknown> m_DeskBarSite;
|
||||||
IUnknown * m_BandObject;
|
CComPtr<IUnknown> m_BandObject;
|
||||||
IDeskBand * m_DeskBand;
|
CComPtr<IDeskBand> m_DeskBand;
|
||||||
IWinEventHandler * m_WinEventHandler;
|
CComPtr<IWinEventHandler> m_WinEventHandler;
|
||||||
HWND m_hWndBand;
|
HWND m_hWndBand;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CMenuSite();
|
CMenuSite();
|
||||||
|
@ -119,7 +119,7 @@ public:
|
||||||
virtual HRESULT STDMETHODCALLTYPE SetModeDBC(DWORD dwMode);
|
virtual HRESULT STDMETHODCALLTYPE SetModeDBC(DWORD dwMode);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
BOOL CreateSiteWindow(HWND hWndParent);
|
IUnknown * ToIUnknown() { return (IDeskBarClient*)this; }
|
||||||
};
|
};
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
|
@ -201,26 +201,11 @@ HRESULT STDMETHODCALLTYPE CMenuSite::AddBand(IUnknown * punk)
|
||||||
|
|
||||||
IUnknown_SetSite(m_BandObject, NULL);
|
IUnknown_SetSite(m_BandObject, NULL);
|
||||||
|
|
||||||
if (m_BandObject)
|
|
||||||
{
|
|
||||||
m_BandObject->Release();
|
|
||||||
m_BandObject = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_DeskBand)
|
|
||||||
{
|
|
||||||
m_DeskBand->Release();
|
|
||||||
m_DeskBand = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_WinEventHandler)
|
|
||||||
{
|
|
||||||
m_WinEventHandler->Release();
|
|
||||||
m_WinEventHandler = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOL result = m_hWndBand != NULL;
|
BOOL result = m_hWndBand != NULL;
|
||||||
|
|
||||||
|
m_BandObject = NULL;
|
||||||
|
m_DeskBand = NULL;
|
||||||
|
m_WinEventHandler = NULL;
|
||||||
m_hWndBand = NULL;
|
m_hWndBand = NULL;
|
||||||
|
|
||||||
if (!punk)
|
if (!punk)
|
||||||
|
@ -229,7 +214,7 @@ HRESULT STDMETHODCALLTYPE CMenuSite::AddBand(IUnknown * punk)
|
||||||
DBGASSERT(SUCCEEDED(punk->QueryInterface(IID_PPV_ARG(IDeskBand, &m_DeskBand))));
|
DBGASSERT(SUCCEEDED(punk->QueryInterface(IID_PPV_ARG(IDeskBand, &m_DeskBand))));
|
||||||
DBGASSERT(SUCCEEDED(punk->QueryInterface(IID_PPV_ARG(IWinEventHandler, &m_WinEventHandler))));
|
DBGASSERT(SUCCEEDED(punk->QueryInterface(IID_PPV_ARG(IWinEventHandler, &m_WinEventHandler))));
|
||||||
|
|
||||||
IUnknown_SetSite(punk, (IDeskBarClient*)this);
|
IUnknown_SetSite(punk, this->ToIUnknown());
|
||||||
IUnknown_GetWindow(punk, &m_hWndBand);
|
IUnknown_GetWindow(punk, &m_hWndBand);
|
||||||
|
|
||||||
m_BandObject = punk;
|
m_BandObject = punk;
|
||||||
|
@ -363,81 +348,51 @@ HRESULT STDMETHODCALLTYPE CMenuSite::QueryStatus(const GUID * pguidCmdGroup, ULO
|
||||||
|
|
||||||
HRESULT STDMETHODCALLTYPE CMenuSite::SetDeskBarSite(IUnknown *punkSite)
|
HRESULT STDMETHODCALLTYPE CMenuSite::SetDeskBarSite(IUnknown *punkSite)
|
||||||
{
|
{
|
||||||
HWND hWndSite;
|
HRESULT hr;
|
||||||
|
|
||||||
((IDeskBarClient*)this)->AddRef();
|
CComPtr<IUnknown> protectThis(this->ToIUnknown());
|
||||||
|
|
||||||
if (punkSite)
|
if (punkSite)
|
||||||
{
|
{
|
||||||
if (m_DeskBarSite)
|
HWND hWndSite;
|
||||||
{
|
|
||||||
m_DeskBarSite->Release();
|
|
||||||
m_DeskBarSite = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
IUnknown_GetWindow(punkSite, &hWndSite);
|
|
||||||
|
|
||||||
if (hWndSite)
|
|
||||||
{
|
|
||||||
CreateSiteWindow(hWndSite);
|
|
||||||
|
|
||||||
m_DeskBarSite = punkSite;
|
|
||||||
|
|
||||||
punkSite->AddRef();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (m_DeskBand)
|
|
||||||
{
|
|
||||||
m_DeskBand->CloseDW(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
IUnknown_SetSite(m_BandObject, NULL);
|
|
||||||
|
|
||||||
if (m_BandObject)
|
|
||||||
{
|
|
||||||
m_BandObject->Release();
|
|
||||||
m_BandObject = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_DeskBand)
|
|
||||||
{
|
|
||||||
m_DeskBand->Release();
|
|
||||||
m_DeskBand = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_WinEventHandler)
|
|
||||||
{
|
|
||||||
m_WinEventHandler->Release();
|
|
||||||
m_WinEventHandler = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
m_hWndBand = NULL;
|
|
||||||
|
|
||||||
if (m_hWnd)
|
|
||||||
{
|
|
||||||
DestroyWindow();
|
|
||||||
m_hWnd = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (m_DeskBarSite)
|
|
||||||
m_DeskBarSite->Release();
|
|
||||||
|
|
||||||
m_DeskBarSite = NULL;
|
m_DeskBarSite = NULL;
|
||||||
|
|
||||||
|
hr = IUnknown_GetWindow(punkSite, &hWndSite);
|
||||||
|
|
||||||
|
if (FAILED(hr) || !hWndSite)
|
||||||
|
return E_FAIL;
|
||||||
|
|
||||||
|
if (!m_hWnd)
|
||||||
|
{
|
||||||
|
Create(hWndSite, NULL, L"MenuSite");
|
||||||
|
}
|
||||||
|
|
||||||
|
m_DeskBarSite = punkSite;
|
||||||
|
|
||||||
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
((IDeskBarClient*)this)->Release();
|
if (m_DeskBand)
|
||||||
|
{
|
||||||
|
m_DeskBand->CloseDW(0);
|
||||||
|
}
|
||||||
|
|
||||||
if (!m_hWnd)
|
IUnknown_SetSite(m_BandObject, NULL);
|
||||||
return E_FAIL;
|
|
||||||
|
m_BandObject = NULL;
|
||||||
|
m_DeskBand = NULL;
|
||||||
|
m_WinEventHandler = NULL;
|
||||||
|
m_hWndBand = NULL;
|
||||||
|
m_hWnd = NULL;
|
||||||
|
m_DeskBarSite = NULL;
|
||||||
|
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
HRESULT STDMETHODCALLTYPE CMenuSite::UIActivateDBC(DWORD dwState)
|
HRESULT STDMETHODCALLTYPE CMenuSite::UIActivateDBC(DWORD dwState)
|
||||||
{
|
{
|
||||||
if (!DBGASSERT(m_DeskBand))
|
if (!m_DeskBand)
|
||||||
return S_OK;
|
return S_OK;
|
||||||
|
|
||||||
return m_DeskBand->ShowDW(dwState != 0);
|
return m_DeskBand->ShowDW(dwState != 0);
|
||||||
|
@ -445,71 +400,49 @@ HRESULT STDMETHODCALLTYPE CMenuSite::UIActivateDBC(DWORD dwState)
|
||||||
|
|
||||||
HRESULT STDMETHODCALLTYPE CMenuSite::UIActivateIO(BOOL fActivate, LPMSG lpMsg)
|
HRESULT STDMETHODCALLTYPE CMenuSite::UIActivateIO(BOOL fActivate, LPMSG lpMsg)
|
||||||
{
|
{
|
||||||
if (lpMsg && DBGASSERT(IsBadWritePtr(lpMsg, sizeof(*lpMsg))))
|
if (lpMsg)
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
|
|
||||||
return IUnknown_UIActivateIO(m_BandObject, fActivate, lpMsg);
|
return IUnknown_UIActivateIO(m_BandObject, fActivate, lpMsg);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL CMenuSite::CreateSiteWindow(HWND hWndParent)
|
|
||||||
{
|
|
||||||
if (m_hWnd)
|
|
||||||
{
|
|
||||||
return DBGASSERT(IsWindow());
|
|
||||||
}
|
|
||||||
|
|
||||||
Create(hWndParent, NULL, L"MenuSite");
|
|
||||||
|
|
||||||
return m_hWnd != NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
BOOL CMenuSite::ProcessWindowMessage(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT &lResult, DWORD mapId)
|
BOOL CMenuSite::ProcessWindowMessage(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam, LRESULT &lResult, DWORD mapId)
|
||||||
{
|
{
|
||||||
HWND hWndToCall;
|
HWND hWndTarget = NULL;
|
||||||
IMenuPopup * pMenuPopup;
|
CComPtr<IUnknown> protectThis(this->ToIUnknown());
|
||||||
|
|
||||||
((IDeskBarClient*)this)->AddRef();
|
|
||||||
|
|
||||||
switch (uMsg)
|
switch (uMsg)
|
||||||
{
|
{
|
||||||
case WM_SIZE:
|
case WM_SIZE:
|
||||||
if (m_BandObject)
|
if (m_BandObject)
|
||||||
{
|
{
|
||||||
|
CComPtr<IMenuPopup> pMenuPopup;
|
||||||
if (SUCCEEDED(m_BandObject->QueryInterface(IID_PPV_ARG(IMenuPopup, &pMenuPopup))))
|
if (SUCCEEDED(m_BandObject->QueryInterface(IID_PPV_ARG(IMenuPopup, &pMenuPopup))))
|
||||||
{
|
{
|
||||||
RECT Rect = { 0 };
|
RECT Rect = { 0 };
|
||||||
GetClientRect(&Rect);
|
GetClientRect(&Rect);
|
||||||
pMenuPopup->OnPosRectChangeDB(&Rect);
|
pMenuPopup->OnPosRectChangeDB(&Rect);
|
||||||
pMenuPopup->Release();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
hWndToCall = hWnd;
|
hWndTarget = hWnd;
|
||||||
lResult = 1;
|
lResult = 1;
|
||||||
break;
|
break;
|
||||||
case WM_NOTIFY:
|
case WM_NOTIFY:
|
||||||
hWndToCall = *(HWND *) lParam;
|
hWndTarget = ((NMHDR *)lParam)->hwndFrom;
|
||||||
break;
|
break;
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
hWndToCall = (HWND) lParam;
|
hWndTarget = (HWND) lParam;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
((IDeskBarClient*)this)->Release();
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hWndToCall)
|
if (hWndTarget && m_WinEventHandler &&
|
||||||
|
m_WinEventHandler->IsWindowOwner(hWndTarget) == S_OK)
|
||||||
{
|
{
|
||||||
if (m_WinEventHandler)
|
if (SUCCEEDED(m_WinEventHandler->OnWinEvent(hWndTarget, uMsg, wParam, lParam, &lResult)))
|
||||||
{
|
return TRUE;
|
||||||
if (m_WinEventHandler->IsWindowOwner(hWndToCall) == S_OK)
|
|
||||||
{
|
|
||||||
HRESULT hr = m_WinEventHandler->OnWinEvent(hWndToCall, uMsg, wParam, lParam, &lResult);
|
|
||||||
((IDeskBarClient*)this)->Release();
|
|
||||||
return hr == S_OK;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
((IDeskBarClient*)this)->Release();
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue