Commit e16d591d authored by Gabriel Ivăncescu's avatar Gabriel Ivăncescu Committed by Alexandre Julliard

comctl32/listbox: Use a helper to retrieve item data by index.

parent b00482e2
...@@ -153,6 +153,11 @@ static BOOL resize_storage(LB_DESCR *descr, UINT items_size) ...@@ -153,6 +153,11 @@ static BOOL resize_storage(LB_DESCR *descr, UINT items_size)
return TRUE; return TRUE;
} }
static ULONG_PTR get_item_data( const LB_DESCR *descr, UINT index )
{
return (descr->style & LBS_NODATA) ? 0 : descr->items[index].data;
}
static BOOL is_item_selected( const LB_DESCR *descr, UINT index ) static BOOL is_item_selected( const LB_DESCR *descr, UINT index )
{ {
if (!(descr->style & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL))) if (!(descr->style & (LBS_MULTIPLESEL | LBS_EXTENDEDSEL)))
...@@ -565,7 +570,7 @@ static void LISTBOX_PaintItem( LB_DESCR *descr, HDC hdc, const RECT *rect, ...@@ -565,7 +570,7 @@ static void LISTBOX_PaintItem( LB_DESCR *descr, HDC hdc, const RECT *rect,
if (focused) if (focused)
dis.itemState |= ODS_FOCUS; dis.itemState |= ODS_FOCUS;
if (!IsWindowEnabled(descr->self)) dis.itemState |= ODS_DISABLED; if (!IsWindowEnabled(descr->self)) dis.itemState |= ODS_DISABLED;
dis.itemData = item ? item->data : 0; dis.itemData = get_item_data(descr, index);
dis.rcItem = *rect; dis.rcItem = *rect;
TRACE("[%p]: drawitem %d (%s) action=%02x state=%02x rect=%s\n", TRACE("[%p]: drawitem %d (%s) action=%02x state=%02x rect=%s\n",
descr->self, index, item ? debugstr_w(item->str) : "", action, descr->self, index, item ? debugstr_w(item->str) : "", action,
...@@ -788,8 +793,7 @@ static LRESULT LISTBOX_GetText( LB_DESCR *descr, INT index, LPWSTR buffer, BOOL ...@@ -788,8 +793,7 @@ static LRESULT LISTBOX_GetText( LB_DESCR *descr, INT index, LPWSTR buffer, BOOL
} else } else
{ {
if (buffer) if (buffer)
*((ULONG_PTR *)buffer) = (descr->style & LBS_NODATA) *((ULONG_PTR *)buffer) = get_item_data(descr, index);
? 0 : descr->items[index].data;
len = sizeof(ULONG_PTR); len = sizeof(ULONG_PTR);
} }
return len; return len;
...@@ -837,7 +841,7 @@ static INT LISTBOX_FindStringPos( LB_DESCR *descr, LPCWSTR str, BOOL exact ) ...@@ -837,7 +841,7 @@ static INT LISTBOX_FindStringPos( LB_DESCR *descr, LPCWSTR str, BOOL exact )
/* note that some application (MetaStock) expects the second item /* note that some application (MetaStock) expects the second item
* to be in the listbox */ * to be in the listbox */
cis.itemID1 = index; cis.itemID1 = index;
cis.itemData1 = descr->items[index].data; cis.itemData1 = get_item_data(descr, index);
cis.itemID2 = -1; cis.itemID2 = -1;
cis.itemData2 = (ULONG_PTR)str; cis.itemData2 = (ULONG_PTR)str;
cis.dwLocaleId = descr->locale; cis.dwLocaleId = descr->locale;
...@@ -1641,7 +1645,7 @@ static LRESULT LISTBOX_InsertString( LB_DESCR *descr, INT index, LPCWSTR str ) ...@@ -1641,7 +1645,7 @@ static LRESULT LISTBOX_InsertString( LB_DESCR *descr, INT index, LPCWSTR str )
static void LISTBOX_DeleteItem( LB_DESCR *descr, INT index ) static void LISTBOX_DeleteItem( LB_DESCR *descr, INT index )
{ {
/* save the item data before it gets freed by LB_RESETCONTENT */ /* save the item data before it gets freed by LB_RESETCONTENT */
ULONG_PTR item_data = descr->items[index].data; ULONG_PTR item_data = get_item_data(descr, index);
LPWSTR item_str = descr->items[index].str; LPWSTR item_str = descr->items[index].str;
if (!descr->nb_items) if (!descr->nb_items)
...@@ -2643,7 +2647,7 @@ static LRESULT CALLBACK LISTBOX_WindowProc( HWND hwnd, UINT msg, WPARAM wParam, ...@@ -2643,7 +2647,7 @@ static LRESULT CALLBACK LISTBOX_WindowProc( HWND hwnd, UINT msg, WPARAM wParam,
SetLastError(ERROR_INVALID_INDEX); SetLastError(ERROR_INVALID_INDEX);
return LB_ERR; return LB_ERR;
} }
return (descr->style & LBS_NODATA) ? 0 : descr->items[wParam].data; return get_item_data(descr, wParam);
case LB_SETITEMDATA: case LB_SETITEMDATA:
if (((INT)wParam < 0) || ((INT)wParam >= descr->nb_items)) if (((INT)wParam < 0) || ((INT)wParam >= descr->nb_items))
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment