- Patch by Victor Matovykh : Cleanup and optimization. See CORE-11479.

svn path=/trunk/; revision=71846
This commit is contained in:
James Tabor 2016-07-07 15:21:54 +00:00
parent 4cf4d58a41
commit eaef5b9f37

View file

@ -943,13 +943,10 @@ VOID UserDrawCaptionBar(
if (!(Style & WS_MINIMIZE))
{
PMENU menu = UserGetMenuObject(UlongToHandle(pWnd->IDMenu));
/* Draw menu bar */
if ( menu && (((Style) & (WS_CHILD | WS_POPUP)) != WS_CHILD) )
if (HAS_MENU(pWnd, Style))
{
TempRect = CurrentRect;
TempRect.bottom = TempRect.top + menu->cyMenu;
CurrentRect.top += MENU_DrawMenuBar(hDC, &TempRect, pWnd, FALSE);
CurrentRect.top += MENU_DrawMenuBar(hDC, &CurrentRect, pWnd, FALSE);
}
if (ExStyle & WS_EX_CLIENTEDGE)
@ -1112,13 +1109,13 @@ NC_DoNCPaint(PWND pWnd, HDC hDC, INT Flags)
if (!(Style & WS_MINIMIZE))
{
PMENU menu = UserGetMenuObject(UlongToHandle(pWnd->IDMenu));
/* Draw menu bar */
if ( menu && (((Style) & (WS_CHILD | WS_POPUP)) != WS_CHILD) )
if (HAS_MENU(pWnd, Style))
{
TempRect = CurrentRect;
TempRect.bottom = TempRect.top + menu->cyMenu;
if (!(Flags & DC_NOSENDMSG)) CurrentRect.top += MENU_DrawMenuBar(hDC, &TempRect, pWnd, FALSE);
if (!(Flags & DC_NOSENDMSG))
{
CurrentRect.top += MENU_DrawMenuBar(hDC, &CurrentRect, pWnd, FALSE);
}
}
if (ExStyle & WS_EX_CLIENTEDGE)
@ -1219,7 +1216,7 @@ LRESULT NC_HandleNCCalcSize( PWND Wnd, WPARAM wparam, RECTL *Rect, BOOL Suspende
Rect->top += UserGetSystemMetrics(SM_CYCAPTION);
}
if (Wnd->IDMenu && ((Wnd->style & (WS_CHILD | WS_POPUP)) != WS_CHILD))
if (HAS_MENU(Wnd, Style))
{
HDC hDC = UserGetDCEx(Wnd, 0, DCX_USESTYLE | DCX_WINDOW);