Slightly improve keyboard tracking in combobox.
diff --git a/controls/listbox.c b/controls/listbox.c
index 252cff7..5960c45 100644
--- a/controls/listbox.c
+++ b/controls/listbox.c
@@ -753,6 +753,8 @@
if (!lParam)
return strlenW(descr->items[index].str);
+ TRACE("index %d (0x%04x) %s\n", index, index, debugstr_w(descr->items[index].str));
+
if(unicode)
{
LPWSTR buffer = (LPWSTR)lParam;
@@ -2046,6 +2048,7 @@
if(!PtInRect(&screenRect, screenMousePos))
{
+ LISTBOX_SetCaretIndex( pWnd, pDescr, pDescr->lphc->droppedIndex, FALSE );
LISTBOX_SetSelection( pWnd, pDescr, pDescr->lphc->droppedIndex, FALSE, FALSE );
COMBO_FlipListbox( pDescr->lphc, FALSE, FALSE );
return 0;
@@ -2745,6 +2748,10 @@
{
INT index;
LPWSTR textW;
+
+ if(HAS_STRINGS(descr))
+ TRACE("LB_SELECTSTRING: %s\n", unicode ? debugstr_w((LPWSTR)lParam) :
+ debugstr_a((LPSTR)lParam));
if(unicode || !HAS_STRINGS(descr))
textW = (LPWSTR)lParam;
else
@@ -2758,7 +2765,10 @@
if(!unicode && HAS_STRINGS(descr))
HeapFree(GetProcessHeap(), 0, textW);
if (index != LB_ERR)
+ {
+ LISTBOX_SetCaretIndex( wnd, descr, index, TRUE );
LISTBOX_SetSelection( wnd, descr, index, TRUE, FALSE );
+ }
return index;
}
@@ -3061,7 +3071,7 @@
WPARAM wParam, LPARAM lParam, BOOL unicode )
{
LRESULT lRet = 0;
- HWND hwnd = wnd->hwndSelf;
+ HWND hwnd;
if (wnd)
{
@@ -3070,6 +3080,8 @@
TRACE_(combo)("[%04x]: msg %s wp %08x lp %08lx\n",
wnd->hwndSelf, SPY_GetMsgName(msg), wParam, lParam );
+ hwnd = wnd->hwndSelf;
+
if( descr || msg == WM_CREATE )
{
LPHEADCOMBO lphc = (descr) ? descr->lphc : NULL;