mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 21:38:43 +00:00
Sync with wine-20040724
svn path=/trunk/; revision=10268
This commit is contained in:
parent
c7c06a5864
commit
bfcd174365
1 changed files with 67 additions and 164 deletions
|
@ -31,6 +31,7 @@
|
||||||
#include "controls.h"
|
#include "controls.h"
|
||||||
#include "user32/regcontrol.h"
|
#include "user32/regcontrol.h"
|
||||||
#include "wine/debug.h"
|
#include "wine/debug.h"
|
||||||
|
#include "wine/unicode.h"
|
||||||
|
|
||||||
WINE_DEFAULT_DEBUG_CHANNEL(combo);
|
WINE_DEFAULT_DEBUG_CHANNEL(combo);
|
||||||
|
|
||||||
|
@ -62,19 +63,12 @@ static UINT CBitHeight, CBitWidth;
|
||||||
/*
|
/*
|
||||||
* Look and feel dependent "constants"
|
* Look and feel dependent "constants"
|
||||||
*/
|
*/
|
||||||
#ifndef __REACTOS__
|
|
||||||
#define COMBO_YBORDERGAP 5
|
#define COMBO_YBORDERGAP 5
|
||||||
#define COMBO_XBORDERSIZE() ( (TWEAK_WineLook == WIN31_LOOK) ? 0 : 2 )
|
#define COMBO_XBORDERSIZE() 2
|
||||||
#define COMBO_YBORDERSIZE() ( (TWEAK_WineLook == WIN31_LOOK) ? 0 : 2 )
|
#define COMBO_YBORDERSIZE() 2
|
||||||
#define COMBO_EDITBUTTONSPACE() ( (TWEAK_WineLook == WIN31_LOOK) ? 8 : 0 )
|
#define COMBO_EDITBUTTONSPACE() 0
|
||||||
#define EDIT_CONTROL_PADDING() ( (TWEAK_WineLook == WIN31_LOOK) ? 0 : 1 )
|
#define EDIT_CONTROL_PADDING() 1
|
||||||
#else /* __REACTOS__ */
|
|
||||||
#define COMBO_YBORDERGAP 5
|
|
||||||
#define COMBO_XBORDERSIZE() ( 2 )
|
|
||||||
#define COMBO_YBORDERSIZE() ( 2 )
|
|
||||||
#define COMBO_EDITBUTTONSPACE() ( 0 )
|
|
||||||
#define EDIT_CONTROL_PADDING() ( 1 )
|
|
||||||
#endif /* __REACTOS__ */
|
|
||||||
|
|
||||||
static LRESULT WINAPI ComboWndProcA( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam );
|
static LRESULT WINAPI ComboWndProcA( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam );
|
||||||
static LRESULT WINAPI ComboWndProcW( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam );
|
static LRESULT WINAPI ComboWndProcW( HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam );
|
||||||
|
@ -84,6 +78,7 @@ static LRESULT WINAPI ComboWndProcW( HWND hwnd, UINT msg, WPARAM wParam, LPARAM
|
||||||
*/
|
*/
|
||||||
const struct builtin_class_descr COMBO_builtin_class =
|
const struct builtin_class_descr COMBO_builtin_class =
|
||||||
{
|
{
|
||||||
|
#ifdef __REACTOS__
|
||||||
L"ComboBox", /* name */
|
L"ComboBox", /* name */
|
||||||
CS_PARENTDC | CS_VREDRAW | CS_HREDRAW | CS_DBLCLKS, /* style */
|
CS_PARENTDC | CS_VREDRAW | CS_HREDRAW | CS_DBLCLKS, /* style */
|
||||||
(WNDPROC) ComboWndProcW, /* procW */
|
(WNDPROC) ComboWndProcW, /* procW */
|
||||||
|
@ -91,6 +86,15 @@ const struct builtin_class_descr COMBO_builtin_class =
|
||||||
sizeof(HEADCOMBO *), /* extra */
|
sizeof(HEADCOMBO *), /* extra */
|
||||||
(LPCWSTR) IDC_ARROW, /* cursor */
|
(LPCWSTR) IDC_ARROW, /* cursor */
|
||||||
0 /* brush */
|
0 /* brush */
|
||||||
|
#else
|
||||||
|
"ComboBox", /* name */
|
||||||
|
CS_PARENTDC | CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW, /* style */
|
||||||
|
ComboWndProcA, /* procA */
|
||||||
|
ComboWndProcW, /* procW */
|
||||||
|
sizeof(HEADCOMBO *), /* extra */
|
||||||
|
IDC_ARROW, /* cursor */
|
||||||
|
0 /* brush */
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -491,9 +495,6 @@ static LRESULT COMBO_WindowPosChanging(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
posChanging->cx = max(posChanging->cx, 0);
|
|
||||||
posChanging->cy = max(posChanging->cy, 0);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -576,13 +577,8 @@ static LRESULT COMBO_Create( HWND hwnd, LPHEADCOMBO lphc, HWND hwndParent, LONG
|
||||||
* In win 95 look n feel, the listbox in the simple combobox has
|
* In win 95 look n feel, the listbox in the simple combobox has
|
||||||
* the WS_EXCLIENTEDGE style instead of the WS_BORDER style.
|
* the WS_EXCLIENTEDGE style instead of the WS_BORDER style.
|
||||||
*/
|
*/
|
||||||
#ifndef __REACTOS__
|
lbeStyle &= ~WS_BORDER;
|
||||||
if (TWEAK_WineLook > WIN31_LOOK)
|
lbeExStyle |= WS_EX_CLIENTEDGE;
|
||||||
#endif /* __REACTOS__ */
|
|
||||||
{
|
|
||||||
lbeStyle &= ~WS_BORDER;
|
|
||||||
lbeExStyle |= WS_EX_CLIENTEDGE;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -611,14 +607,6 @@ static LRESULT COMBO_Create( HWND hwnd, LPHEADCOMBO lphc, HWND hwndParent, LONG
|
||||||
BOOL bEdit = TRUE;
|
BOOL bEdit = TRUE;
|
||||||
lbeStyle = WS_CHILD | WS_VISIBLE | ES_NOHIDESEL | ES_LEFT | ES_COMBO;
|
lbeStyle = WS_CHILD | WS_VISIBLE | ES_NOHIDESEL | ES_LEFT | ES_COMBO;
|
||||||
|
|
||||||
/*
|
|
||||||
* In Win95 look, the border fo the edit control is
|
|
||||||
* provided by the combobox
|
|
||||||
*/
|
|
||||||
#ifndef __REACTOS__
|
|
||||||
if (TWEAK_WineLook == WIN31_LOOK)
|
|
||||||
lbeStyle |= WS_BORDER;
|
|
||||||
#endif /* __REACTOS__ */
|
|
||||||
if( lphc->wState & CBF_EDIT )
|
if( lphc->wState & CBF_EDIT )
|
||||||
{
|
{
|
||||||
if( lphc->dwStyle & CBS_OEMCONVERT )
|
if( lphc->dwStyle & CBS_OEMCONVERT )
|
||||||
|
@ -683,85 +671,21 @@ static LRESULT COMBO_Create( HWND hwnd, LPHEADCOMBO lphc, HWND hwndParent, LONG
|
||||||
*
|
*
|
||||||
* Paint combo button (normal, pressed, and disabled states).
|
* Paint combo button (normal, pressed, and disabled states).
|
||||||
*/
|
*/
|
||||||
static void CBPaintButton(
|
static void CBPaintButton( LPHEADCOMBO lphc, HDC hdc, RECT rectButton)
|
||||||
LPHEADCOMBO lphc,
|
|
||||||
HDC hdc,
|
|
||||||
RECT rectButton)
|
|
||||||
{
|
{
|
||||||
|
UINT buttonState = DFCS_SCROLLCOMBOBOX;
|
||||||
|
|
||||||
if( lphc->wState & CBF_NOREDRAW )
|
if( lphc->wState & CBF_NOREDRAW )
|
||||||
return;
|
return;
|
||||||
#ifndef __REACTOS__
|
|
||||||
if (TWEAK_WineLook == WIN31_LOOK)
|
|
||||||
{
|
|
||||||
UINT x, y;
|
|
||||||
BOOL bBool;
|
|
||||||
HDC hMemDC;
|
|
||||||
HBRUSH hPrevBrush;
|
|
||||||
COLORREF oldTextColor, oldBkColor;
|
|
||||||
|
|
||||||
|
|
||||||
hPrevBrush = SelectObject(hdc, GetSysColorBrush(COLOR_BTNFACE));
|
if (lphc->wState & CBF_BUTTONDOWN)
|
||||||
|
buttonState |= DFCS_PUSHED;
|
||||||
|
|
||||||
/*
|
if (CB_DISABLED(lphc))
|
||||||
* Draw the button background
|
buttonState |= DFCS_INACTIVE;
|
||||||
*/
|
|
||||||
PatBlt( hdc,
|
|
||||||
rectButton.left,
|
|
||||||
rectButton.top,
|
|
||||||
rectButton.right-rectButton.left,
|
|
||||||
rectButton.bottom-rectButton.top,
|
|
||||||
PATCOPY );
|
|
||||||
|
|
||||||
if( (bBool = lphc->wState & CBF_BUTTONDOWN) )
|
DrawFrameControl(hdc, &rectButton, DFC_SCROLL, buttonState);
|
||||||
{
|
|
||||||
DrawEdge( hdc, &rectButton, EDGE_SUNKEN, BF_RECT );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DrawEdge( hdc, &rectButton, EDGE_RAISED, BF_RECT );
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Remove the edge of the button from the rectangle
|
|
||||||
* and calculate the position of the bitmap.
|
|
||||||
*/
|
|
||||||
InflateRect( &rectButton, -2, -2);
|
|
||||||
|
|
||||||
x = (rectButton.left + rectButton.right - CBitWidth) >> 1;
|
|
||||||
y = (rectButton.top + rectButton.bottom - CBitHeight) >> 1;
|
|
||||||
|
|
||||||
|
|
||||||
hMemDC = CreateCompatibleDC( hdc );
|
|
||||||
SelectObject( hMemDC, hComboBmp );
|
|
||||||
oldTextColor = SetTextColor( hdc, GetSysColor(COLOR_BTNFACE) );
|
|
||||||
oldBkColor = SetBkColor( hdc, CB_DISABLED(lphc) ? RGB(128,128,128) :
|
|
||||||
RGB(0,0,0) );
|
|
||||||
BitBlt( hdc, x, y, CBitWidth, CBitHeight, hMemDC, 0, 0, SRCCOPY );
|
|
||||||
SetBkColor( hdc, oldBkColor );
|
|
||||||
SetTextColor( hdc, oldTextColor );
|
|
||||||
DeleteDC( hMemDC );
|
|
||||||
SelectObject( hdc, hPrevBrush );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
#endif /* __REACTOS__ */
|
|
||||||
{
|
|
||||||
UINT buttonState = DFCS_SCROLLCOMBOBOX;
|
|
||||||
|
|
||||||
if (lphc->wState & CBF_BUTTONDOWN)
|
|
||||||
{
|
|
||||||
buttonState |= DFCS_PUSHED;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (CB_DISABLED(lphc))
|
|
||||||
{
|
|
||||||
buttonState |= DFCS_INACTIVE;
|
|
||||||
}
|
|
||||||
|
|
||||||
DrawFrameControl(hdc,
|
|
||||||
&rectButton,
|
|
||||||
DFC_SCROLL,
|
|
||||||
buttonState);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/***********************************************************************
|
/***********************************************************************
|
||||||
|
@ -1033,12 +957,7 @@ static LRESULT COMBO_Paint(LPHEADCOMBO lphc, HDC hParamDC)
|
||||||
/*
|
/*
|
||||||
* In non 3.1 look, there is a sunken border on the combobox
|
* In non 3.1 look, there is a sunken border on the combobox
|
||||||
*/
|
*/
|
||||||
#ifndef __REACTOS__
|
CBPaintBorder(lphc->self, lphc, hDC);
|
||||||
if (TWEAK_WineLook != WIN31_LOOK)
|
|
||||||
#endif
|
|
||||||
{
|
|
||||||
CBPaintBorder(lphc->self, lphc, hDC);
|
|
||||||
}
|
|
||||||
|
|
||||||
if( !IsRectEmpty(&lphc->buttonRect) )
|
if( !IsRectEmpty(&lphc->buttonRect) )
|
||||||
{
|
{
|
||||||
|
@ -1056,25 +975,7 @@ static LRESULT COMBO_Paint(LPHEADCOMBO lphc, HDC hParamDC)
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !(lphc->wState & CBF_EDIT) )
|
if( !(lphc->wState & CBF_EDIT) )
|
||||||
{
|
|
||||||
/*
|
|
||||||
* The text area has a border only in Win 3.1 look.
|
|
||||||
*/
|
|
||||||
#ifndef __REACTOS__
|
|
||||||
if (TWEAK_WineLook == WIN31_LOOK)
|
|
||||||
{
|
|
||||||
HPEN hPrevPen = SelectObject( hDC, SYSCOLOR_GetPen(COLOR_WINDOWFRAME) );
|
|
||||||
|
|
||||||
Rectangle( hDC,
|
|
||||||
lphc->textRect.left, lphc->textRect.top,
|
|
||||||
lphc->textRect.right - 1, lphc->textRect.bottom - 1);
|
|
||||||
|
|
||||||
SelectObject( hDC, hPrevPen );
|
|
||||||
}
|
|
||||||
#endif /* __REACTOS__ */
|
|
||||||
|
|
||||||
CBPaintText( lphc, hDC, lphc->textRect);
|
CBPaintText( lphc, hDC, lphc->textRect);
|
||||||
}
|
|
||||||
|
|
||||||
if( hPrevBrush )
|
if( hPrevBrush )
|
||||||
SelectObject( hDC, hPrevBrush );
|
SelectObject( hDC, hPrevBrush );
|
||||||
|
@ -1448,7 +1349,7 @@ static LRESULT COMBO_Command( LPHEADCOMBO lphc, WPARAM wParam, HWND hWnd )
|
||||||
}
|
}
|
||||||
else if( lphc->hWndLBox == hWnd )
|
else if( lphc->hWndLBox == hWnd )
|
||||||
{
|
{
|
||||||
switch( HIWORD(wParam) )
|
switch( (short)HIWORD(wParam) )
|
||||||
{
|
{
|
||||||
case LBN_ERRSPACE:
|
case LBN_ERRSPACE:
|
||||||
CB_NOTIFY( lphc, CBN_ERRSPACE );
|
CB_NOTIFY( lphc, CBN_ERRSPACE );
|
||||||
|
@ -2012,22 +1913,22 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
case WM_KILLFOCUS:
|
case WM_KILLFOCUS:
|
||||||
{
|
{
|
||||||
#ifndef __REACTOS__
|
#ifdef __REACTOS__
|
||||||
HWND hwndFocus = WIN_GetFullHandle( (HWND)wParam );
|
|
||||||
#else /* __REACTOS__ */
|
|
||||||
HWND hwndFocus = (HWND)wParam;
|
HWND hwndFocus = (HWND)wParam;
|
||||||
#endif /* __REACTOS__ */
|
#else
|
||||||
|
HWND hwndFocus = WIN_GetFullHandle( (HWND)wParam );
|
||||||
|
#endif
|
||||||
if( !hwndFocus ||
|
if( !hwndFocus ||
|
||||||
(hwndFocus != lphc->hWndEdit && hwndFocus != lphc->hWndLBox ))
|
(hwndFocus != lphc->hWndEdit && hwndFocus != lphc->hWndLBox ))
|
||||||
COMBO_KillFocus( lphc );
|
COMBO_KillFocus( lphc );
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
#ifndef __REACTOS__
|
#ifdef __REACTOS__
|
||||||
|
return COMBO_Command( lphc, wParam, (HWND)lParam);
|
||||||
|
#else
|
||||||
return COMBO_Command( lphc, wParam, WIN_GetFullHandle( (HWND)lParam ) );
|
return COMBO_Command( lphc, wParam, WIN_GetFullHandle( (HWND)lParam ) );
|
||||||
#else /* __REACTOS__ */
|
#endif
|
||||||
return COMBO_Command( lphc, wParam, (HWND)lParam );
|
|
||||||
#endif /* __REACTOS__ */
|
|
||||||
case WM_GETTEXT:
|
case WM_GETTEXT:
|
||||||
return unicode ? COMBO_GetTextW( lphc, wParam, (LPWSTR)lParam )
|
return unicode ? COMBO_GetTextW( lphc, wParam, (LPWSTR)lParam )
|
||||||
: COMBO_GetTextA( lphc, wParam, (LPSTR)lParam );
|
: COMBO_GetTextA( lphc, wParam, (LPSTR)lParam );
|
||||||
|
@ -2133,18 +2034,19 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
/* Combo messages */
|
/* Combo messages */
|
||||||
|
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_ADDSTRING16:
|
case CB_ADDSTRING16:
|
||||||
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_ADDSTRING:
|
case CB_ADDSTRING:
|
||||||
if( unicode )
|
if( unicode )
|
||||||
{
|
{
|
||||||
if( lphc->dwStyle & CBS_LOWERCASE )
|
if( lphc->dwStyle & CBS_LOWERCASE )
|
||||||
_wcslwr((LPWSTR)lParam);
|
strlwrW((LPWSTR)lParam);
|
||||||
else if( lphc->dwStyle & CBS_UPPERCASE )
|
else if( lphc->dwStyle & CBS_UPPERCASE )
|
||||||
_wcsupr((LPWSTR)lParam);
|
struprW((LPWSTR)lParam);
|
||||||
return SendMessageW(lphc->hWndLBox, LB_ADDSTRING, 0, lParam);
|
return SendMessageW(lphc->hWndLBox, LB_ADDSTRING, 0, lParam);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2160,14 +2062,14 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_INSERTSTRING:
|
case CB_INSERTSTRING:
|
||||||
if( unicode )
|
if( unicode )
|
||||||
{
|
{
|
||||||
if( lphc->dwStyle & CBS_LOWERCASE )
|
if( lphc->dwStyle & CBS_LOWERCASE )
|
||||||
_wcslwr((LPWSTR)lParam);
|
strlwrW((LPWSTR)lParam);
|
||||||
else if( lphc->dwStyle & CBS_UPPERCASE )
|
else if( lphc->dwStyle & CBS_UPPERCASE )
|
||||||
_wcsupr((LPWSTR)lParam);
|
struprW((LPWSTR)lParam);
|
||||||
return SendMessageW(lphc->hWndLBox, LB_INSERTSTRING, wParam, lParam);
|
return SendMessageW(lphc->hWndLBox, LB_INSERTSTRING, wParam, lParam);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -2180,7 +2082,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
}
|
}
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_DELETESTRING16:
|
case CB_DELETESTRING16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_DELETESTRING:
|
case CB_DELETESTRING:
|
||||||
return unicode ? SendMessageW(lphc->hWndLBox, LB_DELETESTRING, wParam, 0) :
|
return unicode ? SendMessageW(lphc->hWndLBox, LB_DELETESTRING, wParam, 0) :
|
||||||
SendMessageA(lphc->hWndLBox, LB_DELETESTRING, wParam, 0);
|
SendMessageA(lphc->hWndLBox, LB_DELETESTRING, wParam, 0);
|
||||||
|
@ -2189,7 +2091,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SELECTSTRING:
|
case CB_SELECTSTRING:
|
||||||
return COMBO_SelectString(lphc, (INT)wParam, lParam, unicode);
|
return COMBO_SelectString(lphc, (INT)wParam, lParam, unicode);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
|
@ -2197,7 +2099,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_FINDSTRING:
|
case CB_FINDSTRING:
|
||||||
return unicode ? SendMessageW(lphc->hWndLBox, LB_FINDSTRING, wParam, lParam) :
|
return unicode ? SendMessageW(lphc->hWndLBox, LB_FINDSTRING, wParam, lParam) :
|
||||||
SendMessageA(lphc->hWndLBox, LB_FINDSTRING, wParam, lParam);
|
SendMessageA(lphc->hWndLBox, LB_FINDSTRING, wParam, lParam);
|
||||||
|
@ -2206,7 +2108,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
if( CB_HASSTRINGS(lphc) ) lParam = (LPARAM)MapSL(lParam);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_FINDSTRINGEXACT:
|
case CB_FINDSTRINGEXACT:
|
||||||
return unicode ? SendMessageW(lphc->hWndLBox, LB_FINDSTRINGEXACT, wParam, lParam) :
|
return unicode ? SendMessageW(lphc->hWndLBox, LB_FINDSTRINGEXACT, wParam, lParam) :
|
||||||
SendMessageA(lphc->hWndLBox, LB_FINDSTRINGEXACT, wParam, lParam);
|
SendMessageA(lphc->hWndLBox, LB_FINDSTRINGEXACT, wParam, lParam);
|
||||||
|
@ -2214,21 +2116,21 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
case CB_SETITEMHEIGHT16:
|
case CB_SETITEMHEIGHT16:
|
||||||
wParam = (INT)(INT16)wParam; /* signed integer */
|
wParam = (INT)(INT16)wParam; /* signed integer */
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SETITEMHEIGHT:
|
case CB_SETITEMHEIGHT:
|
||||||
return COMBO_SetItemHeight( lphc, (INT)wParam, (INT)lParam);
|
return COMBO_SetItemHeight( lphc, (INT)wParam, (INT)lParam);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_GETITEMHEIGHT16:
|
case CB_GETITEMHEIGHT16:
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETITEMHEIGHT:
|
case CB_GETITEMHEIGHT:
|
||||||
if( (INT)wParam >= 0 ) /* listbox item */
|
if( (INT)wParam >= 0 ) /* listbox item */
|
||||||
return SendMessageW(lphc->hWndLBox, LB_GETITEMHEIGHT, wParam, 0);
|
return SendMessageW(lphc->hWndLBox, LB_GETITEMHEIGHT, wParam, 0);
|
||||||
return CBGetTextAreaHeight(hwnd, lphc);
|
return CBGetTextAreaHeight(hwnd, lphc);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_RESETCONTENT16:
|
case CB_RESETCONTENT16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_RESETCONTENT:
|
case CB_RESETCONTENT:
|
||||||
SendMessageW(lphc->hWndLBox, LB_RESETCONTENT, 0, 0);
|
SendMessageW(lphc->hWndLBox, LB_RESETCONTENT, 0, 0);
|
||||||
if( (lphc->wState & CBF_EDIT) && CB_HASSTRINGS(lphc) )
|
if( (lphc->wState & CBF_EDIT) && CB_HASSTRINGS(lphc) )
|
||||||
|
@ -2269,25 +2171,26 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
CONV_RECT32TO16( &r, (LPRECT16)lParam );
|
CONV_RECT32TO16( &r, (LPRECT16)lParam );
|
||||||
}
|
}
|
||||||
return CB_OKAY;
|
return CB_OKAY;
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETDROPPEDCONTROLRECT:
|
case CB_GETDROPPEDCONTROLRECT:
|
||||||
if( lParam ) CBGetDroppedControlRect(lphc, (LPRECT)lParam );
|
if( lParam ) CBGetDroppedControlRect(lphc, (LPRECT)lParam );
|
||||||
return CB_OKAY;
|
return CB_OKAY;
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_GETDROPPEDSTATE16:
|
case CB_GETDROPPEDSTATE16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETDROPPEDSTATE:
|
case CB_GETDROPPEDSTATE:
|
||||||
return (lphc->wState & CBF_DROPPED) ? TRUE : FALSE;
|
return (lphc->wState & CBF_DROPPED) ? TRUE : FALSE;
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_DIR16:
|
case CB_DIR16:
|
||||||
return SendMessageA(lphc->hWndLBox, LB_DIR16, wParam, lParam);
|
return SendMessageA(lphc->hWndLBox, LB_DIR16, wParam, lParam);
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_DIR:
|
case CB_DIR:
|
||||||
return unicode ? SendMessageW(lphc->hWndLBox, LB_DIR, wParam, lParam) :
|
return unicode ? SendMessageW(lphc->hWndLBox, LB_DIR, wParam, lParam) :
|
||||||
SendMessageA(lphc->hWndLBox, LB_DIR, wParam, lParam);
|
SendMessageA(lphc->hWndLBox, LB_DIR, wParam, lParam);
|
||||||
|
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_SHOWDROPDOWN16:
|
case CB_SHOWDROPDOWN16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SHOWDROPDOWN:
|
case CB_SHOWDROPDOWN:
|
||||||
if( CB_GETTYPE(lphc) != CBS_SIMPLE )
|
if( CB_GETTYPE(lphc) != CBS_SIMPLE )
|
||||||
{
|
{
|
||||||
|
@ -2303,19 +2206,19 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
return TRUE;
|
return TRUE;
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_GETCOUNT16:
|
case CB_GETCOUNT16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETCOUNT:
|
case CB_GETCOUNT:
|
||||||
return SendMessageW(lphc->hWndLBox, LB_GETCOUNT, 0, 0);
|
return SendMessageW(lphc->hWndLBox, LB_GETCOUNT, 0, 0);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_GETCURSEL16:
|
case CB_GETCURSEL16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETCURSEL:
|
case CB_GETCURSEL:
|
||||||
return SendMessageW(lphc->hWndLBox, LB_GETCURSEL, 0, 0);
|
return SendMessageW(lphc->hWndLBox, LB_GETCURSEL, 0, 0);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_SETCURSEL16:
|
case CB_SETCURSEL16:
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SETCURSEL:
|
case CB_SETCURSEL:
|
||||||
lParam = SendMessageW(lphc->hWndLBox, LB_SETCURSEL, wParam, 0);
|
lParam = SendMessageW(lphc->hWndLBox, LB_SETCURSEL, wParam, 0);
|
||||||
if( lParam >= 0 )
|
if( lParam >= 0 )
|
||||||
|
@ -2333,7 +2236,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
lParam = (LPARAM)MapSL(lParam);
|
lParam = (LPARAM)MapSL(lParam);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETLBTEXT:
|
case CB_GETLBTEXT:
|
||||||
return unicode ? SendMessageW(lphc->hWndLBox, LB_GETTEXT, wParam, lParam) :
|
return unicode ? SendMessageW(lphc->hWndLBox, LB_GETTEXT, wParam, lParam) :
|
||||||
SendMessageA(lphc->hWndLBox, LB_GETTEXT, wParam, lParam);
|
SendMessageA(lphc->hWndLBox, LB_GETTEXT, wParam, lParam);
|
||||||
|
@ -2341,7 +2244,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
case CB_GETLBTEXTLEN16:
|
case CB_GETLBTEXTLEN16:
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETLBTEXTLEN:
|
case CB_GETLBTEXTLEN:
|
||||||
return unicode ? SendMessageW(lphc->hWndLBox, LB_GETTEXTLEN, wParam, 0) :
|
return unicode ? SendMessageW(lphc->hWndLBox, LB_GETTEXTLEN, wParam, 0) :
|
||||||
SendMessageA(lphc->hWndLBox, LB_GETTEXTLEN, wParam, 0);
|
SendMessageA(lphc->hWndLBox, LB_GETTEXTLEN, wParam, 0);
|
||||||
|
@ -2349,21 +2252,21 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
case CB_GETITEMDATA16:
|
case CB_GETITEMDATA16:
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETITEMDATA:
|
case CB_GETITEMDATA:
|
||||||
return SendMessageW(lphc->hWndLBox, LB_GETITEMDATA, wParam, 0);
|
return SendMessageW(lphc->hWndLBox, LB_GETITEMDATA, wParam, 0);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_SETITEMDATA16:
|
case CB_SETITEMDATA16:
|
||||||
wParam = (INT)(INT16)wParam;
|
wParam = (INT)(INT16)wParam;
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SETITEMDATA:
|
case CB_SETITEMDATA:
|
||||||
return SendMessageW(lphc->hWndLBox, LB_SETITEMDATA, wParam, lParam);
|
return SendMessageW(lphc->hWndLBox, LB_SETITEMDATA, wParam, lParam);
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_GETEDITSEL16:
|
case CB_GETEDITSEL16:
|
||||||
wParam = lParam = 0; /* just in case */
|
wParam = lParam = 0; /* just in case */
|
||||||
/* fall through */
|
/* fall through */
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETEDITSEL:
|
case CB_GETEDITSEL:
|
||||||
/* Edit checks passed parameters itself */
|
/* Edit checks passed parameters itself */
|
||||||
if( lphc->wState & CBF_EDIT )
|
if( lphc->wState & CBF_EDIT )
|
||||||
|
@ -2371,15 +2274,15 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
return CB_ERR;
|
return CB_ERR;
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_SETEDITSEL16:
|
case CB_SETEDITSEL16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SETEDITSEL:
|
case CB_SETEDITSEL:
|
||||||
if( lphc->wState & CBF_EDIT )
|
if( lphc->wState & CBF_EDIT )
|
||||||
return SendMessageW(lphc->hWndEdit, EM_SETSEL,
|
return SendMessageW(lphc->hWndEdit, EM_SETSEL,
|
||||||
(INT)(USHORT)LOWORD(lParam), (INT)(USHORT)HIWORD(lParam) );
|
(INT)(INT16)LOWORD(lParam), (INT)(INT16)HIWORD(lParam) );
|
||||||
return CB_ERR;
|
return CB_ERR;
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_SETEXTENDEDUI16:
|
case CB_SETEXTENDEDUI16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_SETEXTENDEDUI:
|
case CB_SETEXTENDEDUI:
|
||||||
if( CB_GETTYPE(lphc) == CBS_SIMPLE )
|
if( CB_GETTYPE(lphc) == CBS_SIMPLE )
|
||||||
return CB_ERR;
|
return CB_ERR;
|
||||||
|
@ -2389,7 +2292,7 @@ static LRESULT ComboWndProc_common( HWND hwnd, UINT message,
|
||||||
return CB_OKAY;
|
return CB_OKAY;
|
||||||
#ifndef __REACTOS__
|
#ifndef __REACTOS__
|
||||||
case CB_GETEXTENDEDUI16:
|
case CB_GETEXTENDEDUI16:
|
||||||
#endif /* __REACTOS__ */
|
#endif
|
||||||
case CB_GETEXTENDEDUI:
|
case CB_GETEXTENDEDUI:
|
||||||
return (lphc->wState & CBF_EUI) ? TRUE : FALSE;
|
return (lphc->wState & CBF_EUI) ? TRUE : FALSE;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue