Removed the gotos from the WndProcs, always use a small wrapper that

locks the window, calls the real wndproc, unlocks the window.
This commit is contained in:
Marcus Meissner 1999-05-01 10:23:45 +00:00 committed by Alexandre Julliard
parent f78e41a3dc
commit 9aded5135c
4 changed files with 273 additions and 416 deletions

View File

@ -73,15 +73,16 @@ static WORD checkBoxWidth = 0, checkBoxHeight = 0;
/***********************************************************************
* ButtonWndProc
* ButtonWndProc_locked
*
* Called with window lock held.
*/
LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
WPARAM wParam, LPARAM lParam )
static inline LRESULT WINAPI ButtonWndProc_locked(WND* wndPtr, UINT uMsg,
WPARAM wParam, LPARAM lParam )
{
RECT rect;
LRESULT retvalue;
HWND hWnd = wndPtr->hwndSelf;
POINT pt;
WND *wndPtr = WIN_FindWndPtr(hWnd);
BUTTONINFO *infoPtr = (BUTTONINFO *)wndPtr->wExtra;
LONG style = wndPtr->dwStyle & 0x0f;
HANDLE oldHbitmap;
@ -92,7 +93,6 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
switch (uMsg)
{
case WM_GETDLGCODE:
WIN_ReleaseWndPtr(wndPtr);
switch(style)
{
case BS_PUSHBUTTON: return DLGC_BUTTON | DLGC_UNDEFPUSHBUTTON;
@ -123,11 +123,9 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
infoPtr->state = BUTTON_UNCHECKED;
infoPtr->hFont = 0;
infoPtr->hImage = NULL;
WIN_ReleaseWndPtr(wndPtr);
return 0;
case WM_ERASEBKGND:
WIN_ReleaseWndPtr(wndPtr);
return 1;
case WM_PAINT:
@ -184,7 +182,6 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
break;
case WM_NCHITTEST:
WIN_ReleaseWndPtr(wndPtr);
if(style == BS_GROUPBOX) return HTTRANSPARENT;
return DefWindowProcA( hWnd, uMsg, wParam, lParam );
@ -192,7 +189,6 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
DEFWND_SetText( wndPtr, (LPCSTR)lParam );
if( wndPtr->dwStyle & WS_VISIBLE )
PAINT_BUTTON( wndPtr, style, ODA_DRAWENTIRE );
WIN_ReleaseWndPtr(wndPtr);
return 0;
case WM_SETFONT:
@ -202,16 +198,12 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
break;
case WM_GETFONT:
retvalue = infoPtr->hFont;
WIN_ReleaseWndPtr(wndPtr);
return retvalue;
return infoPtr->hFont;
case WM_SETFOCUS:
infoPtr->state |= BUTTON_HASFOCUS;
if (style == BS_AUTORADIOBUTTON)
{
SendMessageA( hWnd, BM_SETCHECK, 1, 0 );
}
PAINT_BUTTON( wndPtr, style, ODA_FOCUS );
break;
@ -238,19 +230,14 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
oldHbitmap = infoPtr->hImage;
if(wndPtr->dwStyle & BS_BITMAP)
infoPtr->hImage = (HANDLE) lParam;
WIN_ReleaseWndPtr(wndPtr);
return oldHbitmap;
case BM_GETIMAGE:
retvalue = infoPtr->hImage;
WIN_ReleaseWndPtr(wndPtr);
return retvalue;
return infoPtr->hImage;
case BM_GETCHECK16:
case BM_GETCHECK:
retvalue = infoPtr->state & 3;
WIN_ReleaseWndPtr(wndPtr);
return retvalue;
return infoPtr->state & 3;
case BM_SETCHECK16:
case BM_SETCHECK:
@ -273,9 +260,7 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
case BM_GETSTATE16:
case BM_GETSTATE:
retvalue = infoPtr->state;
WIN_ReleaseWndPtr(wndPtr);
return retvalue;
return infoPtr->state;
case BM_SETSTATE16:
case BM_SETSTATE:
@ -293,13 +278,28 @@ LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
break;
default:
WIN_ReleaseWndPtr(wndPtr);
return DefWindowProcA(hWnd, uMsg, wParam, lParam);
}
WIN_ReleaseWndPtr(wndPtr);
return 0;
}
/***********************************************************************
* ButtonWndProc
* The button window procedure. This is just a wrapper which locks
* the passed HWND and calls the real window procedure (with a WND*
* pointer pointing to the locked windowstructure).
*/
LRESULT WINAPI ButtonWndProc( HWND hWnd, UINT uMsg,
WPARAM wParam, LPARAM lParam )
{
LRESULT res;
WND *wndPtr = WIN_FindWndPtr(hWnd);
res = ButtonWndProc_locked(wndPtr,uMsg,wParam,lParam);
WIN_ReleaseWndPtr(wndPtr);
return res;
}
/**********************************************************************
* Push Button Functions

View File

@ -1679,19 +1679,16 @@ static void COMBO_MouseMove( LPHEADCOMBO lphc, WPARAM wParam, LPARAM lParam )
/***********************************************************************
* ComboWndProc
* ComboWndProc_locked
*
* http://www.microsoft.com/msdn/sdk/platforms/doc/sdk/win32/ctrl/src/combobox_15.htm
*/
LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
static inline LRESULT WINAPI ComboWndProc_locked( WND* pWnd, UINT message,
WPARAM wParam, LPARAM lParam )
{
LRESULT retvalue;
WND* pWnd = WIN_FindWndPtr(hwnd);
if( pWnd )
{
if( pWnd ) {
LPHEADCOMBO lphc = CB_GETPTR(pWnd);
HWND hwnd = pWnd->hwndSelf;
TRACE(combo, "[%04x]: msg %s wp %08x lp %08lx\n",
pWnd->hwndSelf, SPY_GetMsgName(message), wParam, lParam );
@ -1703,15 +1700,13 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
/* System messages */
case WM_NCCREATE:
retvalue = COMBO_NCCreate(pWnd, lParam);
goto END;
return COMBO_NCCreate(pWnd, lParam);
case WM_NCDESTROY:
COMBO_NCDestroy(lphc);
break;
break;/* -> DefWindowProc */
case WM_CREATE:
retvalue = COMBO_Create(lphc, pWnd, lParam);
goto END;
return COMBO_Create(lphc, pWnd, lParam);
case WM_PRINTCLIENT:
if (lParam & PRF_ERASEBKGND)
@ -1720,50 +1715,39 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
/* Fallthrough */
case WM_PAINT:
/* wParam may contain a valid HDC! */
retvalue = COMBO_Paint(lphc, wParam);
goto END;
return COMBO_Paint(lphc, wParam);
case WM_ERASEBKGND:
retvalue = COMBO_EraseBackground(hwnd, lphc, wParam);
goto END;
return COMBO_EraseBackground(hwnd, lphc, wParam);
case WM_GETDLGCODE:
retvalue = (LRESULT)(DLGC_WANTARROWS | DLGC_WANTCHARS);
goto END;
return (LRESULT)(DLGC_WANTARROWS | DLGC_WANTCHARS);
case WM_WINDOWPOSCHANGING:
retvalue = COMBO_WindowPosChanging(hwnd, lphc, (LPWINDOWPOS)lParam);
goto END;
return COMBO_WindowPosChanging(hwnd, lphc, (LPWINDOWPOS)lParam);
case WM_SIZE:
if( lphc->hWndLBox &&
!(lphc->wState & CBF_NORESIZE) ) COMBO_Size( lphc );
retvalue = TRUE;
goto END;
return TRUE;
case WM_SETFONT:
COMBO_Font( lphc, (HFONT16)wParam, (BOOL)lParam );
retvalue = TRUE;
goto END;
return TRUE;
case WM_GETFONT:
retvalue = (LRESULT)lphc->hFont;
goto END;
return (LRESULT)lphc->hFont;
case WM_SETFOCUS:
if( lphc->wState & CBF_EDIT )
SetFocus( lphc->hWndEdit );
else
COMBO_SetFocus( lphc );
retvalue = TRUE;
goto END;
return TRUE;
case WM_KILLFOCUS:
#define hwndFocus ((HWND16)wParam)
if( !hwndFocus ||
(hwndFocus != lphc->hWndEdit && hwndFocus != lphc->hWndLBox ))
COMBO_KillFocus( lphc );
#undef hwndFocus
retvalue = TRUE;
goto END;
return TRUE;
case WM_COMMAND:
retvalue = COMBO_Command( lphc, wParam, (HWND)lParam );
goto END;
return COMBO_Command( lphc, wParam, (HWND)lParam );
case WM_GETTEXT:
retvalue = COMBO_GetText( lphc, (UINT)wParam, (LPSTR)lParam );
goto END;
return COMBO_GetText( lphc, (UINT)wParam, (LPSTR)lParam );
case WM_SETTEXT:
case WM_GETTEXTLENGTH:
case WM_CLEAR:
@ -1771,24 +1755,18 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
case WM_PASTE:
case WM_COPY:
if( lphc->wState & CBF_EDIT )
{
retvalue = SendMessageA( lphc->hWndEdit, message, wParam, lParam );
goto END;
}
retvalue = CB_ERR;
goto END;
return SendMessageA( lphc->hWndEdit, message, wParam, lParam );
return CB_ERR;
case WM_DRAWITEM:
case WM_DELETEITEM:
case WM_COMPAREITEM:
case WM_MEASUREITEM:
retvalue = COMBO_ItemOp( lphc, message, wParam, lParam );
goto END;
return COMBO_ItemOp( lphc, message, wParam, lParam );
case WM_ENABLE:
if( lphc->wState & CBF_EDIT )
EnableWindow( lphc->hWndEdit, (BOOL)wParam );
EnableWindow( lphc->hWndLBox, (BOOL)wParam );
retvalue = TRUE;
goto END;
return TRUE;
case WM_SETREDRAW:
if( wParam )
lphc->wState &= ~CBF_NOREDRAW;
@ -1798,123 +1776,95 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
if( lphc->wState & CBF_EDIT )
SendMessageA( lphc->hWndEdit, message, wParam, lParam );
SendMessageA( lphc->hWndLBox, message, wParam, lParam );
retvalue = 0;
goto END;
return 0;
case WM_SYSKEYDOWN:
if( KEYDATA_ALT & HIWORD(lParam) )
if( wParam == VK_UP || wParam == VK_DOWN )
COMBO_FlipListbox( lphc, TRUE );
break;
break;/* -> DefWindowProc */
case WM_CHAR:
case WM_KEYDOWN:
if( lphc->wState & CBF_EDIT )
retvalue = SendMessageA( lphc->hWndEdit, message, wParam, lParam );
return SendMessageA( lphc->hWndEdit, message, wParam, lParam );
else
retvalue = SendMessageA( lphc->hWndLBox, message, wParam, lParam );
goto END;
return SendMessageA( lphc->hWndLBox, message, wParam, lParam );
case WM_LBUTTONDOWN:
if( !(lphc->wState & CBF_FOCUSED) ) SetFocus( lphc->self->hwndSelf );
if( lphc->wState & CBF_FOCUSED ) COMBO_LButtonDown( lphc, lParam );
retvalue = TRUE;
goto END;
return TRUE;
case WM_LBUTTONUP:
COMBO_LButtonUp( lphc, lParam );
retvalue = TRUE;
goto END;
return TRUE;
case WM_MOUSEMOVE:
if( lphc->wState & CBF_CAPTURE )
COMBO_MouseMove( lphc, wParam, lParam );
retvalue = TRUE;
goto END;
return TRUE;
/* Combo messages */
case CB_ADDSTRING16:
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
case CB_ADDSTRING:
retvalue = SendMessageA( lphc->hWndLBox, LB_ADDSTRING, 0, lParam);
goto END;
return SendMessageA( lphc->hWndLBox, LB_ADDSTRING, 0, lParam);
case CB_INSERTSTRING16:
wParam = (INT)(INT16)wParam;
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
case CB_INSERTSTRING:
retvalue = SendMessageA( lphc->hWndLBox, LB_INSERTSTRING, wParam, lParam);
goto END;
return SendMessageA( lphc->hWndLBox, LB_INSERTSTRING, wParam, lParam);
case CB_DELETESTRING16:
case CB_DELETESTRING:
retvalue = SendMessageA( lphc->hWndLBox, LB_DELETESTRING, wParam, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_DELETESTRING, wParam, 0);
case CB_SELECTSTRING16:
wParam = (INT)(INT16)wParam;
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
case CB_SELECTSTRING:
retvalue = COMBO_SelectString( lphc, (INT)wParam, (LPSTR)lParam );
goto END;
return COMBO_SelectString( lphc, (INT)wParam, (LPSTR)lParam );
case CB_FINDSTRING16:
wParam = (INT)(INT16)wParam;
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
case CB_FINDSTRING:
retvalue = SendMessageA( lphc->hWndLBox, LB_FINDSTRING, wParam, lParam);
goto END;
return SendMessageA( lphc->hWndLBox, LB_FINDSTRING, wParam, lParam);
case CB_FINDSTRINGEXACT16:
wParam = (INT)(INT16)wParam;
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
case CB_FINDSTRINGEXACT:
retvalue = SendMessageA( lphc->hWndLBox, LB_FINDSTRINGEXACT,
return SendMessageA( lphc->hWndLBox, LB_FINDSTRINGEXACT,
wParam, lParam );
goto END;
case CB_SETITEMHEIGHT16:
wParam = (INT)(INT16)wParam; /* signed integer */
case CB_SETITEMHEIGHT:
retvalue = COMBO_SetItemHeight( lphc, (INT)wParam, (INT)lParam);
goto END;
return COMBO_SetItemHeight( lphc, (INT)wParam, (INT)lParam);
case CB_GETITEMHEIGHT16:
wParam = (INT)(INT16)wParam;
case CB_GETITEMHEIGHT:
if( (INT)wParam >= 0 ) /* listbox item */
{
retvalue = SendMessageA( lphc->hWndLBox, LB_GETITEMHEIGHT, wParam, 0);
goto END;
}
retvalue = CBGetTextAreaHeight(hwnd, lphc);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETITEMHEIGHT, wParam, 0);
return CBGetTextAreaHeight(hwnd, lphc);
case CB_RESETCONTENT16:
case CB_RESETCONTENT:
SendMessageA( lphc->hWndLBox, LB_RESETCONTENT, 0, 0 );
InvalidateRect(CB_HWND(lphc), NULL, TRUE);
retvalue = TRUE;
goto END;
return TRUE;
case CB_INITSTORAGE:
retvalue = SendMessageA( lphc->hWndLBox, LB_INITSTORAGE, wParam, lParam);
goto END;
return SendMessageA( lphc->hWndLBox, LB_INITSTORAGE, wParam, lParam);
case CB_GETHORIZONTALEXTENT:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETHORIZONTALEXTENT, 0, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETHORIZONTALEXTENT, 0, 0);
case CB_SETHORIZONTALEXTENT:
retvalue = SendMessageA( lphc->hWndLBox, LB_SETHORIZONTALEXTENT, wParam, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_SETHORIZONTALEXTENT, wParam, 0);
case CB_GETTOPINDEX:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETTOPINDEX, 0, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETTOPINDEX, 0, 0);
case CB_GETLOCALE:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETLOCALE, 0, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETLOCALE, 0, 0);
case CB_SETLOCALE:
retvalue = SendMessageA( lphc->hWndLBox, LB_SETLOCALE, wParam, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_SETLOCALE, wParam, 0);
case CB_GETDROPPEDWIDTH:
if( lphc->droppedWidth )
{
retvalue = lphc->droppedWidth;
goto END;
}
retvalue = lphc->droppedRect.right - lphc->droppedRect.left;
goto END;
return lphc->droppedWidth;
return lphc->droppedRect.right - lphc->droppedRect.left;
case CB_SETDROPPEDWIDTH:
if( (CB_GETTYPE(lphc) != CBS_SIMPLE) &&
(INT)wParam < 32768 ) lphc->droppedWidth = (INT)wParam;
retvalue = CB_ERR;
goto END;
return CB_ERR;
case CB_GETDROPPEDCONTROLRECT16:
lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
if( lParam )
@ -1923,23 +1873,19 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
CBGetDroppedControlRect( lphc, &r );
CONV_RECT32TO16( &r, (LPRECT16)lParam );
}
retvalue = CB_OKAY;
goto END;
return CB_OKAY;
case CB_GETDROPPEDCONTROLRECT:
if( lParam ) CBGetDroppedControlRect(lphc, (LPRECT)lParam );
retvalue = CB_OKAY;
goto END;
return CB_OKAY;
case CB_GETDROPPEDSTATE16:
case CB_GETDROPPEDSTATE:
retvalue = (lphc->wState & CBF_DROPPED) ? TRUE : FALSE;
goto END;
return (lphc->wState & CBF_DROPPED) ? TRUE : FALSE;
case CB_DIR16:
lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
/* fall through */
case CB_DIR:
retvalue = COMBO_Directory( lphc, (UINT)wParam,
return COMBO_Directory( lphc, (UINT)wParam,
(LPSTR)lParam, (message == CB_DIR));
goto END;
case CB_SHOWDROPDOWN16:
case CB_SHOWDROPDOWN:
if( CB_GETTYPE(lphc) != CBS_SIMPLE )
@ -1953,16 +1899,13 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
if( lphc->wState & CBF_DROPPED )
CBRollUp( lphc, FALSE, TRUE );
}
retvalue = TRUE;
goto END;
return TRUE;
case CB_GETCOUNT16:
case CB_GETCOUNT:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETCOUNT, 0, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETCOUNT, 0, 0);
case CB_GETCURSEL16:
case CB_GETCURSEL:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETCURSEL, 0, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETCURSEL, 0, 0);
case CB_SETCURSEL16:
wParam = (INT)(INT16)wParam;
case CB_SETCURSEL:
@ -1973,29 +1916,24 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
InvalidateRect(CB_HWND(lphc), &lphc->textRect, TRUE);
lphc->wState &= ~CBF_SELCHANGE;
}
retvalue = lParam;
goto END;
return lParam;
case CB_GETLBTEXT16:
wParam = (INT)(INT16)wParam;
lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
case CB_GETLBTEXT:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETTEXT, wParam, lParam);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETTEXT, wParam, lParam);
case CB_GETLBTEXTLEN16:
wParam = (INT)(INT16)wParam;
case CB_GETLBTEXTLEN:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETTEXTLEN, wParam, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETTEXTLEN, wParam, 0);
case CB_GETITEMDATA16:
wParam = (INT)(INT16)wParam;
case CB_GETITEMDATA:
retvalue = SendMessageA( lphc->hWndLBox, LB_GETITEMDATA, wParam, 0);
goto END;
return SendMessageA( lphc->hWndLBox, LB_GETITEMDATA, wParam, 0);
case CB_SETITEMDATA16:
wParam = (INT)(INT16)wParam;
case CB_SETITEMDATA:
retvalue = SendMessageA( lphc->hWndLBox, LB_SETITEMDATA, wParam, lParam);
goto END;
return SendMessageA( lphc->hWndLBox, LB_SETITEMDATA, wParam, lParam);
case CB_GETEDITSEL16:
wParam = lParam = 0; /* just in case */
case CB_GETEDITSEL:
@ -2003,47 +1941,49 @@ LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
{
INT a, b;
retvalue = SendMessageA( lphc->hWndEdit, EM_GETSEL,
return SendMessageA( lphc->hWndEdit, EM_GETSEL,
(wParam) ? wParam : (WPARAM)&a,
(lParam) ? lParam : (LPARAM)&b );
goto END;
}
retvalue = CB_ERR;
goto END;
return CB_ERR;
case CB_SETEDITSEL16:
case CB_SETEDITSEL:
if( lphc->wState & CBF_EDIT )
{
retvalue = SendMessageA( lphc->hWndEdit, EM_SETSEL,
return SendMessageA( lphc->hWndEdit, EM_SETSEL,
(INT)(INT16)LOWORD(lParam), (INT)(INT16)HIWORD(lParam) );
goto END;
}
retvalue = CB_ERR;
goto END;
return CB_ERR;
case CB_SETEXTENDEDUI16:
case CB_SETEXTENDEDUI:
if( CB_GETTYPE(lphc) == CBS_SIMPLE )
{
retvalue = CB_ERR;
goto END;
}
return CB_ERR;
if( wParam )
lphc->wState |= CBF_EUI;
else lphc->wState &= ~CBF_EUI;
retvalue = CB_OKAY;
goto END;
return CB_OKAY;
case CB_GETEXTENDEDUI16:
case CB_GETEXTENDEDUI:
retvalue = (lphc->wState & CBF_EUI) ? TRUE : FALSE;
goto END;
return (lphc->wState & CBF_EUI) ? TRUE : FALSE;
case (WM_USER + 0x1B):
WARN(combo, "[%04x]: undocumented msg!\n", hwnd );
}
retvalue = DefWindowProcA(hwnd, message, wParam, lParam);
goto END;
return DefWindowProcA(hwnd, message, wParam, lParam);
}
retvalue = CB_ERR;
END:
return CB_ERR;
}
/***********************************************************************
* ComboWndProc
*
* This is just a wrapper for the real ComboWndProc which locks/unlocks
* window structs.
*/
LRESULT WINAPI ComboWndProc( HWND hwnd, UINT message,
WPARAM wParam, LPARAM lParam )
{
WND* pWnd = WIN_FindWndPtr(hwnd);
LRESULT retvalue = ComboWndProc_locked(pWnd,message,wParam,lParam);
WIN_ReleaseWndPtr(pWnd);
return retvalue;
}

View File

@ -194,16 +194,15 @@ static LRESULT DESKTOP_DoEraseBkgnd( HWND hwnd, HDC hdc,
/***********************************************************************
* DesktopWndProc
* DesktopWndProc_locked
*
* Window procedure for the desktop window.
*/
LRESULT WINAPI DesktopWndProc( HWND hwnd, UINT message,
static inline LRESULT WINAPI DesktopWndProc_locked( WND *wndPtr, UINT message,
WPARAM wParam, LPARAM lParam )
{
LRESULT retvalue;
WND *wndPtr = WIN_FindWndPtr( hwnd );
DESKTOP *desktopPtr = (DESKTOP *)wndPtr->wExtra;
HWND hwnd = wndPtr->hwndSelf;
/* Most messages are ignored (we DON'T call DefWindowProc) */
@ -216,33 +215,37 @@ LRESULT WINAPI DesktopWndProc( HWND hwnd, UINT message,
desktopPtr->hbitmapWallPaper = 0;
SetDeskPattern();
SetDeskWallPaper( (LPSTR)-1 );
retvalue = 1;
goto END;
return 1;
case WM_ERASEBKGND:
if(!DESKTOP_IsSingleWindow())
{
retvalue = 1;
goto END;
}
retvalue = DESKTOP_DoEraseBkgnd( hwnd, (HDC)wParam, desktopPtr );
goto END;
return 1;
return DESKTOP_DoEraseBkgnd( hwnd, (HDC)wParam, desktopPtr );
case WM_SYSCOMMAND:
if ((wParam & 0xfff0) != SC_CLOSE)
{
retvalue = 0;
goto END;
}
return 0;
ExitWindows16( 0, 0 );
case WM_SETCURSOR:
retvalue = (LRESULT)SetCursor16( LoadCursor16( 0, IDC_ARROW16 ) );
goto END;
return (LRESULT)SetCursor16( LoadCursor16( 0, IDC_ARROW16 ) );
}
retvalue = 0;
END:
return 0;
}
/***********************************************************************
* DesktopWndProc
*
* This is just a wrapper for the DesktopWndProc which does windows
* locking and unlocking.
*/
LRESULT WINAPI DesktopWndProc( HWND hwnd, UINT message,
WPARAM wParam, LPARAM lParam )
{
WND *wndPtr = WIN_FindWndPtr( hwnd );
LRESULT retvalue = DesktopWndProc_locked(wndPtr,message,wParam,lParam);
WIN_ReleaseWndPtr(wndPtr);
return retvalue;
}

View File

@ -2130,13 +2130,12 @@ static BOOL LISTBOX_Destroy( WND *wnd, LB_DESCR *descr )
/***********************************************************************
* ListBoxWndProc
*/
LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
WPARAM wParam, LPARAM lParam )
static inline LRESULT WINAPI ListBoxWndProc_locked( WND* wnd, UINT msg,
WPARAM wParam, LPARAM lParam )
{
LRESULT ret;
LB_DESCR *descr;
WND *wnd = WIN_FindWndPtr( hwnd );
LRESULT retvalue;
HWND hwnd = wnd->hwndSelf;
if (!wnd) return 0;
if (!(descr = *(LB_DESCR **)wnd->wExtra))
@ -2144,18 +2143,13 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
if (msg == WM_CREATE)
{
if (!LISTBOX_Create( wnd, NULL ))
{
retvalue = -1;
goto END;
}
return -1;
TRACE(listbox, "creating wnd=%04x descr=%p\n",
hwnd, *(LB_DESCR **)wnd->wExtra );
retvalue = 0;
goto END;
return 0;
}
/* Ignore all other messages before we get a WM_CREATE */
retvalue = DefWindowProcA( hwnd, msg, wParam, lParam );
goto END;
return DefWindowProcA( hwnd, msg, wParam, lParam );
}
TRACE(listbox, "[%04x]: msg %s wp %08x lp %08lx\n",
@ -2165,112 +2159,88 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
case LB_RESETCONTENT16:
case LB_RESETCONTENT:
LISTBOX_ResetContent( wnd, descr );
retvalue = 0;
goto END;
return 0;
case LB_ADDSTRING16:
if (HAS_STRINGS(descr)) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
/* fall through */
case LB_ADDSTRING:
wParam = LISTBOX_FindStringPos( wnd, descr, (LPCSTR)lParam, FALSE );
retvalue = LISTBOX_InsertString( wnd, descr, wParam, (LPCSTR)lParam );
goto END;
return LISTBOX_InsertString( wnd, descr, wParam, (LPCSTR)lParam );
case LB_INSERTSTRING16:
if (HAS_STRINGS(descr)) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
wParam = (INT)(INT16)wParam;
/* fall through */
case LB_INSERTSTRING:
retvalue = LISTBOX_InsertString( wnd, descr, wParam, (LPCSTR)lParam );
goto END;
return LISTBOX_InsertString( wnd, descr, wParam, (LPCSTR)lParam );
case LB_ADDFILE16:
if (HAS_STRINGS(descr)) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
/* fall through */
case LB_ADDFILE:
wParam = LISTBOX_FindFileStrPos( wnd, descr, (LPCSTR)lParam );
retvalue = LISTBOX_InsertString( wnd, descr, wParam, (LPCSTR)lParam );
goto END;
return LISTBOX_InsertString( wnd, descr, wParam, (LPCSTR)lParam );
case LB_DELETESTRING16:
case LB_DELETESTRING:
retvalue = LISTBOX_RemoveItem( wnd, descr, wParam );
goto END;
return LISTBOX_RemoveItem( wnd, descr, wParam );
case LB_GETITEMDATA16:
case LB_GETITEMDATA:
if (((INT)wParam < 0) || ((INT)wParam >= descr->nb_items))
{
retvalue = LB_ERR;
goto END;
}
retvalue = descr->items[wParam].data;
goto END;
return LB_ERR;
return descr->items[wParam].data;
case LB_SETITEMDATA16:
case LB_SETITEMDATA:
if (((INT)wParam < 0) || ((INT)wParam >= descr->nb_items))
{
retvalue = LB_ERR;
goto END;
}
return LB_ERR;
descr->items[wParam].data = (DWORD)lParam;
retvalue = LB_OKAY;
goto END;
return LB_OKAY;
case LB_GETCOUNT16:
case LB_GETCOUNT:
retvalue = descr->nb_items;
goto END;
return descr->nb_items;
case LB_GETTEXT16:
lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
/* fall through */
case LB_GETTEXT:
retvalue = LISTBOX_GetText( wnd, descr, wParam, (LPSTR)lParam );
goto END;
return LISTBOX_GetText( wnd, descr, wParam, (LPSTR)lParam );
case LB_GETTEXTLEN16:
/* fall through */
case LB_GETTEXTLEN:
if (wParam >= descr->nb_items)
{
retvalue = LB_ERR;
goto END;
}
retvalue = (HAS_STRINGS(descr) ? strlen(descr->items[wParam].str)
return LB_ERR;
return (HAS_STRINGS(descr) ? strlen(descr->items[wParam].str)
: sizeof(DWORD));
goto END;
case LB_GETCURSEL16:
case LB_GETCURSEL:
if (descr->nb_items==0)
retvalue = LB_ERR;
else
{
retvalue = descr->selected_item;
if (retvalue == -1) retvalue = descr->focus_item;
}
return LB_ERR;
/* else */
if (descr->selected_item!=-1)
return descr->selected_item;
/* else */
return descr->focus_item;
/* otherwise, if the user tries to move the selection with the */
/* arrow keys, we will give the application something to choke on */
goto END;
case LB_GETTOPINDEX16:
case LB_GETTOPINDEX:
retvalue = descr->top_item;
goto END;
return descr->top_item;
case LB_GETITEMHEIGHT16:
case LB_GETITEMHEIGHT:
retvalue = LISTBOX_GetItemHeight( wnd, descr, wParam );
goto END;
return LISTBOX_GetItemHeight( wnd, descr, wParam );
case LB_SETITEMHEIGHT16:
lParam = LOWORD(lParam);
/* fall through */
case LB_SETITEMHEIGHT:
retvalue = LISTBOX_SetItemHeight( wnd, descr, wParam, lParam );
goto END;
return LISTBOX_SetItemHeight( wnd, descr, wParam, lParam );
case LB_ITEMFROMPOINT:
{
@ -2284,30 +2254,25 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
rect.right = descr->width;
rect.bottom = descr->height;
retvalue = MAKELONG( LISTBOX_GetItemFromPoint(wnd, descr, pt.x, pt.y),
return MAKELONG( LISTBOX_GetItemFromPoint(wnd, descr, pt.x, pt.y),
PtInRect( &rect, pt ) );
goto END;
}
case LB_SETCARETINDEX16:
case LB_SETCARETINDEX:
retvalue = LISTBOX_SetCaretIndex( wnd, descr, wParam, !lParam );
goto END;
return LISTBOX_SetCaretIndex( wnd, descr, wParam, !lParam );
case LB_GETCARETINDEX16:
case LB_GETCARETINDEX:
retvalue = descr->focus_item;
goto END;
return descr->focus_item;
case LB_SETTOPINDEX16:
case LB_SETTOPINDEX:
retvalue = LISTBOX_SetTopItem( wnd, descr, wParam, TRUE );
goto END;
return LISTBOX_SetTopItem( wnd, descr, wParam, TRUE );
case LB_SETCOLUMNWIDTH16:
case LB_SETCOLUMNWIDTH:
retvalue = LISTBOX_SetColumnWidth( wnd, descr, wParam );
goto END;
return LISTBOX_SetColumnWidth( wnd, descr, wParam );
case LB_GETITEMRECT16:
{
@ -2315,28 +2280,24 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
ret = LISTBOX_GetItemRect( wnd, descr, (INT16)wParam, &rect );
CONV_RECT32TO16( &rect, (RECT16 *)PTR_SEG_TO_LIN(lParam) );
}
retvalue = ret;
goto END;
return ret;
case LB_GETITEMRECT:
retvalue = LISTBOX_GetItemRect( wnd, descr, wParam, (RECT *)lParam );
goto END;
return LISTBOX_GetItemRect( wnd, descr, wParam, (RECT *)lParam );
case LB_FINDSTRING16:
wParam = (INT)(INT16)wParam;
if (HAS_STRINGS(descr)) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
/* fall through */
case LB_FINDSTRING:
retvalue = LISTBOX_FindString( wnd, descr, wParam, (LPCSTR)lParam, FALSE );
goto END;
return LISTBOX_FindString( wnd, descr, wParam, (LPCSTR)lParam, FALSE );
case LB_FINDSTRINGEXACT16:
wParam = (INT)(INT16)wParam;
if (HAS_STRINGS(descr)) lParam = (LPARAM)PTR_SEG_TO_LIN(lParam);
/* fall through */
case LB_FINDSTRINGEXACT:
retvalue = LISTBOX_FindString( wnd, descr, wParam, (LPCSTR)lParam, TRUE );
goto END;
return LISTBOX_FindString( wnd, descr, wParam, (LPCSTR)lParam, TRUE );
case LB_SELECTSTRING16:
wParam = (INT)(INT16)wParam;
@ -2347,13 +2308,9 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
INT index = LISTBOX_FindString( wnd, descr, wParam,
(LPCSTR)lParam, FALSE );
if (index == LB_ERR)
{
retvalue = LB_ERR;
goto END;
}
return LB_ERR;
LISTBOX_SetSelection( wnd, descr, index, TRUE, FALSE );
retvalue = index;
goto END;
return index;
}
case LB_GETSEL16:
@ -2361,171 +2318,129 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
/* fall through */
case LB_GETSEL:
if (((INT)wParam < 0) || ((INT)wParam >= descr->nb_items))
{
retvalue = LB_ERR;
goto END;
}
retvalue = descr->items[wParam].selected;
goto END;
return LB_ERR;
return descr->items[wParam].selected;
case LB_SETSEL16:
lParam = (INT)(INT16)lParam;
/* fall through */
case LB_SETSEL:
retvalue = LISTBOX_SetSelection( wnd, descr, lParam, wParam, FALSE );
goto END;
return LISTBOX_SetSelection( wnd, descr, lParam, wParam, FALSE );
case LB_SETCURSEL16:
wParam = (INT)(INT16)wParam;
/* fall through */
case LB_SETCURSEL:
LISTBOX_SetCaretIndex( wnd, descr, wParam, TRUE );
retvalue = LISTBOX_SetSelection( wnd, descr, wParam, TRUE, FALSE );
goto END;
return LISTBOX_SetSelection( wnd, descr, wParam, TRUE, FALSE );
case LB_GETSELCOUNT16:
case LB_GETSELCOUNT:
retvalue = LISTBOX_GetSelCount( wnd, descr );
goto END;
return LISTBOX_GetSelCount( wnd, descr );
case LB_GETSELITEMS16:
retvalue = LISTBOX_GetSelItems16( wnd, descr, wParam,
return LISTBOX_GetSelItems16( wnd, descr, wParam,
(LPINT16)PTR_SEG_TO_LIN(lParam) );
goto END;
case LB_GETSELITEMS:
retvalue = LISTBOX_GetSelItems( wnd, descr, wParam, (LPINT)lParam );
goto END;
return LISTBOX_GetSelItems( wnd, descr, wParam, (LPINT)lParam );
case LB_SELITEMRANGE16:
case LB_SELITEMRANGE:
if (LOWORD(lParam) <= HIWORD(lParam))
{
retvalue = LISTBOX_SelectItemRange( wnd, descr, LOWORD(lParam),
return LISTBOX_SelectItemRange( wnd, descr, LOWORD(lParam),
HIWORD(lParam), wParam );
}
else
{
retvalue = LISTBOX_SelectItemRange( wnd, descr, HIWORD(lParam),
return LISTBOX_SelectItemRange( wnd, descr, HIWORD(lParam),
LOWORD(lParam), wParam );
}
goto END;
case LB_SELITEMRANGEEX16:
case LB_SELITEMRANGEEX:
if ((INT)lParam >= (INT)wParam)
retvalue = LISTBOX_SelectItemRange( wnd, descr, wParam, lParam, TRUE );
return LISTBOX_SelectItemRange( wnd, descr, wParam, lParam, TRUE );
else
retvalue = LISTBOX_SelectItemRange( wnd, descr, lParam, wParam, FALSE);
goto END;
return LISTBOX_SelectItemRange( wnd, descr, lParam, wParam, FALSE);
case LB_GETHORIZONTALEXTENT16:
case LB_GETHORIZONTALEXTENT:
retvalue = descr->horz_extent;
goto END;
return descr->horz_extent;
case LB_SETHORIZONTALEXTENT16:
case LB_SETHORIZONTALEXTENT:
retvalue = LISTBOX_SetHorizontalExtent( wnd, descr, wParam );
goto END;
return LISTBOX_SetHorizontalExtent( wnd, descr, wParam );
case LB_GETANCHORINDEX16:
case LB_GETANCHORINDEX:
retvalue = descr->anchor_item;
goto END;
return descr->anchor_item;
case LB_SETANCHORINDEX16:
wParam = (INT)(INT16)wParam;
/* fall through */
case LB_SETANCHORINDEX:
if (((INT)wParam < -1) || ((INT)wParam >= descr->nb_items))
{
retvalue = LB_ERR;
goto END;
}
return LB_ERR;
descr->anchor_item = (INT)wParam;
retvalue = LB_OKAY;
goto END;
return LB_OKAY;
case LB_DIR16:
retvalue = LISTBOX_Directory( wnd, descr, wParam,
return LISTBOX_Directory( wnd, descr, wParam,
(LPCSTR)PTR_SEG_TO_LIN(lParam), FALSE );
goto END;
case LB_DIR:
retvalue = LISTBOX_Directory( wnd, descr, wParam, (LPCSTR)lParam, TRUE );
goto END;
return LISTBOX_Directory( wnd, descr, wParam, (LPCSTR)lParam, TRUE );
case LB_GETLOCALE:
retvalue = descr->locale;
goto END;
return descr->locale;
case LB_SETLOCALE:
descr->locale = (LCID)wParam; /* FIXME: should check for valid lcid */
retvalue = LB_OKAY;
goto END;
return LB_OKAY;
case LB_INITSTORAGE:
retvalue = LISTBOX_InitStorage( wnd, descr, wParam, (DWORD)lParam );
goto END;
return LISTBOX_InitStorage( wnd, descr, wParam, (DWORD)lParam );
case LB_SETCOUNT:
retvalue = LISTBOX_SetCount( wnd, descr, (INT)wParam );
goto END;
return LISTBOX_SetCount( wnd, descr, (INT)wParam );
case LB_SETTABSTOPS16:
retvalue = LISTBOX_SetTabStops( wnd, descr, (INT)(INT16)wParam,
return LISTBOX_SetTabStops( wnd, descr, (INT)(INT16)wParam,
(LPINT)PTR_SEG_TO_LIN(lParam), TRUE );
goto END;
case LB_SETTABSTOPS:
retvalue = LISTBOX_SetTabStops( wnd, descr, wParam,
(LPINT)lParam, FALSE );
goto END;
return LISTBOX_SetTabStops( wnd, descr, wParam, (LPINT)lParam, FALSE );
case LB_CARETON16:
case LB_CARETON:
if (descr->caret_on)
{
retvalue = LB_OKAY;
goto END;
}
return LB_OKAY;
descr->caret_on = TRUE;
if ((descr->focus_item != -1) && (GetFocus() == wnd->hwndSelf))
LISTBOX_RepaintItem( wnd, descr, descr->focus_item, ODA_FOCUS );
retvalue = LB_OKAY;
goto END;
return LB_OKAY;
case LB_CARETOFF16:
case LB_CARETOFF:
if (!descr->caret_on)
{
retvalue = LB_OKAY;
goto END;
}
return LB_OKAY;
descr->caret_on = FALSE;
if ((descr->focus_item != -1) && (GetFocus() == wnd->hwndSelf))
LISTBOX_RepaintItem( wnd, descr, descr->focus_item, ODA_FOCUS );
retvalue = LB_OKAY;
goto END;
return LB_OKAY;
case WM_DESTROY:
retvalue = LISTBOX_Destroy( wnd, descr );
goto END;
return LISTBOX_Destroy( wnd, descr );
case WM_ENABLE:
InvalidateRect( hwnd, NULL, TRUE );
retvalue = 0;
goto END;
return 0;
case WM_SETREDRAW:
LISTBOX_SetRedraw( wnd, descr, wParam != 0 );
retvalue = 0;
goto END;
return 0;
case WM_GETDLGCODE:
retvalue =DLGC_WANTARROWS | DLGC_WANTCHARS;
goto END;
return DLGC_WANTARROWS | DLGC_WANTCHARS;
case WM_PAINT:
{
PAINTSTRUCT ps;
@ -2534,67 +2449,52 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
ret = LISTBOX_Paint( wnd, descr, hdc );
if( !wParam ) EndPaint( hwnd, &ps );
}
retvalue =ret;
goto END;
return ret;
case WM_SIZE:
LISTBOX_UpdateSize( wnd, descr );
retvalue =0;
goto END;
return 0;
case WM_GETFONT:
retvalue =descr->font;
goto END;
return descr->font;
case WM_SETFONT:
LISTBOX_SetFont( wnd, descr, (HFONT)wParam );
if (lParam) InvalidateRect( wnd->hwndSelf, 0, TRUE );
retvalue =0;
goto END;
return 0;
case WM_SETFOCUS:
descr->caret_on = TRUE;
if (descr->focus_item != -1)
LISTBOX_RepaintItem( wnd, descr, descr->focus_item, ODA_FOCUS );
SEND_NOTIFICATION( wnd, descr, LBN_SETFOCUS );
retvalue =0;
goto END;
return 0;
case WM_KILLFOCUS:
if ((descr->focus_item != -1) && descr->caret_on)
LISTBOX_RepaintItem( wnd, descr, descr->focus_item, ODA_FOCUS );
SEND_NOTIFICATION( wnd, descr, LBN_KILLFOCUS );
retvalue =0;
goto END;
return 0;
case WM_HSCROLL:
retvalue =LISTBOX_HandleHScroll( wnd, descr, wParam, lParam );
goto END;
return LISTBOX_HandleHScroll( wnd, descr, wParam, lParam );
case WM_VSCROLL:
retvalue =LISTBOX_HandleVScroll( wnd, descr, wParam, lParam );
goto END;
return LISTBOX_HandleVScroll( wnd, descr, wParam, lParam );
case WM_LBUTTONDOWN:
retvalue =LISTBOX_HandleLButtonDown( wnd, descr, wParam,
return LISTBOX_HandleLButtonDown( wnd, descr, wParam,
(INT16)LOWORD(lParam),
(INT16)HIWORD(lParam) );
goto END;
case WM_LBUTTONDBLCLK:
if (descr->style & LBS_NOTIFY)
SEND_NOTIFICATION( wnd, descr, LBN_DBLCLK );
retvalue =0;
goto END;
return 0;
case WM_MOUSEMOVE:
if (GetCapture() == hwnd)
LISTBOX_HandleMouseMove( wnd, descr, (INT16)LOWORD(lParam),
(INT16)HIWORD(lParam) );
retvalue =0;
goto END;
return 0;
case WM_LBUTTONUP:
retvalue =LISTBOX_HandleLButtonUp( wnd, descr );
goto END;
return LISTBOX_HandleLButtonUp( wnd, descr );
case WM_KEYDOWN:
retvalue =LISTBOX_HandleKeyDown( wnd, descr, wParam );
goto END;
return LISTBOX_HandleKeyDown( wnd, descr, wParam );
case WM_CHAR:
retvalue =LISTBOX_HandleChar( wnd, descr, wParam );
goto END;
return LISTBOX_HandleChar( wnd, descr, wParam );
case WM_SYSTIMER:
retvalue =LISTBOX_HandleSystemTimer( wnd, descr );
goto END;
return LISTBOX_HandleSystemTimer( wnd, descr );
case WM_ERASEBKGND:
if (IS_OWNERDRAW(descr))
{
@ -2604,14 +2504,10 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
GetClientRect(hwnd, &rect);
if (hbrush) FillRect( (HDC)wParam, &rect, hbrush );
}
retvalue =1;
goto END;
return 1;
case WM_DROPFILES:
if( !descr->lphc )
{
retvalue =SendMessageA( descr->owner, msg, wParam, lParam );
goto END;
}
return SendMessageA( descr->owner, msg, wParam, lParam );
break;
case WM_DROPOBJECT:
@ -2623,27 +2519,37 @@ LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
LPDRAGINFO dragInfo = (LPDRAGINFO)PTR_SEG_TO_LIN( (SEGPTR)lParam );
dragInfo->l = LISTBOX_GetItemFromPoint( wnd, descr, dragInfo->pt.x,
dragInfo->pt.y );
retvalue =SendMessageA( descr->owner, msg, wParam, lParam );
goto END;
return SendMessageA( descr->owner, msg, wParam, lParam );
}
break;
case WM_NCCREATE:
if (TWEAK_WineLook > WIN31_LOOK)
wnd->dwExStyle |= WS_EX_CLIENTEDGE;
retvalue =DefWindowProcA( hwnd, msg, wParam, lParam );
goto END;
return DefWindowProcA( hwnd, msg, wParam, lParam );
default:
if ((msg >= WM_USER) && (msg < 0xc000))
WARN(listbox, "[%04x]: unknown msg %04x wp %08x lp %08lx\n",
hwnd, msg, wParam, lParam );
retvalue =DefWindowProcA( hwnd, msg, wParam, lParam );
goto END;
return DefWindowProcA( hwnd, msg, wParam, lParam );
}
retvalue =0;
END:
WIN_ReleaseWndPtr(wnd);
return retvalue;
return 0;
}
/***********************************************************************
* ListBoxWndProc
*
* This is just a wrapper for the real wndproc, it only does window locking
* and unlocking.
*/
LRESULT WINAPI ListBoxWndProc( HWND hwnd, UINT msg,
WPARAM wParam, LPARAM lParam )
{
WND* wndPtr = WIN_FindWndPtr( hwnd );
LRESULT res = ListBoxWndProc_locked(wndPtr,msg,wParam,lParam);
WIN_ReleaseWndPtr(wndPtr);
return res;
}
/***********************************************************************
@ -2671,16 +2577,15 @@ LRESULT COMBO_Directory( LPHEADCOMBO lphc, UINT attrib, LPSTR dir, BOOL bLong)
}
/***********************************************************************
* ComboLBWndProc
* ComboLBWndProc_locked
*
* NOTE: in Windows, winproc address of the ComboLBox is the same
* as that of the Listbox.
* The real combo listbox wndproc, but called with locked WND struct.
*/
LRESULT WINAPI ComboLBWndProc( HWND hwnd, UINT msg,
static inline LRESULT WINAPI ComboLBWndProc_locked( WND* wnd, UINT msg,
WPARAM wParam, LPARAM lParam )
{
LRESULT lRet = 0;
WND *wnd = WIN_FindWndPtr( hwnd );
HWND hwnd = wnd->hwndSelf;
if (wnd)
{
@ -2702,20 +2607,16 @@ LRESULT WINAPI ComboLBWndProc( HWND hwnd, UINT msg,
lphc = (LPHEADCOMBO)(lpcs->lpCreateParams);
#undef lpcs
lRet =LISTBOX_Create( wnd, lphc );
goto END;
return LISTBOX_Create( wnd, lphc );
case WM_LBUTTONDOWN:
lRet =LISTBOX_HandleLButtonDown( wnd, descr, wParam,
return LISTBOX_HandleLButtonDown( wnd, descr, wParam,
(INT16)LOWORD(lParam), (INT16)HIWORD(lParam));
goto END;
/* avoid activation at all costs */
case WM_MOUSEACTIVATE:
lRet =MA_NOACTIVATE;
goto END;
return MA_NOACTIVATE;
case WM_NCACTIVATE:
lRet =FALSE;
goto END;
return FALSE;
case WM_KEYDOWN:
if( CB_GETTYPE(lphc) != CBS_SIMPLE )
{
@ -2727,34 +2628,47 @@ LRESULT WINAPI ComboLBWndProc( HWND hwnd, UINT msg,
&& (wParam == VK_DOWN || wParam == VK_UP)) )
{
COMBO_FlipListbox( lphc, FALSE );
lRet =0;
goto END;
return 0;
}
}
lRet =LISTBOX_HandleKeyDown( wnd, descr, wParam );
goto END;
return LISTBOX_HandleKeyDown( wnd, descr, wParam );
case LB_SETCURSEL16:
case LB_SETCURSEL:
lRet = ListBoxWndProc( hwnd, msg, wParam, lParam );
lRet =(lRet == LB_ERR) ? lRet : descr->selected_item;
goto END;
return lRet;
case WM_NCDESTROY:
if( CB_GETTYPE(lphc) != CBS_SIMPLE )
lphc->hWndLBox = 0;
/* fall through */
default:
lRet =ListBoxWndProc( hwnd, msg, wParam, lParam );
goto END;
return ListBoxWndProc( hwnd, msg, wParam, lParam );
}
}
lRet = DefWindowProcA( hwnd, msg, wParam, lParam );
TRACE(combo,"\t default on msg [%04x]\n", (UINT16)msg );
}
END:
WIN_ReleaseWndPtr(wnd);
return lRet;
}
/***********************************************************************
* ComboLBWndProc
*
* NOTE: in Windows, winproc address of the ComboLBox is the same
* as that of the Listbox.
*
* This is just a wrapper for the real wndproc, it only does window locking
* and unlocking.
*/
LRESULT WINAPI ComboLBWndProc( HWND hwnd, UINT msg,
WPARAM wParam, LPARAM lParam )
{
WND *wnd = WIN_FindWndPtr( hwnd );
LRESULT res = ComboLBWndProc_locked(wnd,msg,wParam,lParam);
WIN_ReleaseWndPtr(wnd);
return res;
}