Commit dd3fc178 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

comctl32/listview: Add callback subitem on column insertion.

parent 860329d6
...@@ -4276,8 +4276,7 @@ static BOOL set_sub_item(const LISTVIEW_INFO *infoPtr, const LVITEMW *lpLVItem, ...@@ -4276,8 +4276,7 @@ static BOOL set_sub_item(const LISTVIEW_INFO *infoPtr, const LVITEMW *lpLVItem,
*bChanged = TRUE; *bChanged = TRUE;
} }
if (lpLVItem->mask & LVIF_IMAGE) if ((lpLVItem->mask & LVIF_IMAGE) && (lpSubItem->hdr.iImage != lpLVItem->iImage))
if (lpSubItem->hdr.iImage != lpLVItem->iImage)
{ {
lpSubItem->hdr.iImage = lpLVItem->iImage; lpSubItem->hdr.iImage = lpLVItem->iImage;
*bChanged = TRUE; *bChanged = TRUE;
...@@ -7883,6 +7882,13 @@ static INT LISTVIEW_InsertColumnT(LISTVIEW_INFO *infoPtr, INT nColumn, ...@@ -7883,6 +7882,13 @@ static INT LISTVIEW_InsertColumnT(LISTVIEW_INFO *infoPtr, INT nColumn,
SUBITEM_INFO *lpSubItem; SUBITEM_INFO *lpSubItem;
HDPA hdpaSubItems; HDPA hdpaSubItems;
INT nItem, i; INT nItem, i;
LVITEMW item;
BOOL changed;
item.iSubItem = nNewColumn;
item.mask = LVIF_TEXT | LVIF_IMAGE;
item.iImage = I_IMAGECALLBACK;
item.pszText = LPSTR_TEXTCALLBACKW;
for (nItem = 0; nItem < infoPtr->nItemCount; nItem++) for (nItem = 0; nItem < infoPtr->nItemCount; nItem++)
{ {
...@@ -7893,6 +7899,10 @@ static INT LISTVIEW_InsertColumnT(LISTVIEW_INFO *infoPtr, INT nColumn, ...@@ -7893,6 +7899,10 @@ static INT LISTVIEW_InsertColumnT(LISTVIEW_INFO *infoPtr, INT nColumn,
if (lpSubItem->iSubItem >= nNewColumn) if (lpSubItem->iSubItem >= nNewColumn)
lpSubItem->iSubItem++; lpSubItem->iSubItem++;
} }
/* add new subitem for each item */
item.iItem = nItem;
set_sub_item(infoPtr, &item, isW, &changed);
} }
} }
......
...@@ -45,7 +45,7 @@ ...@@ -45,7 +45,7 @@
static const WCHAR testparentclassW[] = static const WCHAR testparentclassW[] =
{'L','i','s','t','v','i','e','w',' ','t','e','s','t',' ','p','a','r','e','n','t','W', 0}; {'L','i','s','t','v','i','e','w',' ','t','e','s','t',' ','p','a','r','e','n','t','W', 0};
HWND hwndparent, hwndparentW; static HWND hwndparent, hwndparentW;
/* prevents edit box creation, LVN_BEGINLABELEDIT return value */ /* prevents edit box creation, LVN_BEGINLABELEDIT return value */
static BOOL blockEdit; static BOOL blockEdit;
/* return nonzero on NM_HOVER */ /* return nonzero on NM_HOVER */
...@@ -54,9 +54,11 @@ static BOOL g_block_hover; ...@@ -54,9 +54,11 @@ static BOOL g_block_hover;
static BOOL g_dump_itemchanged; static BOOL g_dump_itemchanged;
/* format reported to control: /* format reported to control:
-1 falls to defproc, anything else returned */ -1 falls to defproc, anything else returned */
INT notifyFormat; static INT notifyFormat;
/* indicates we're running < 5.80 version */ /* indicates we're running < 5.80 version */
BOOL g_is_below_5; static BOOL g_is_below_5;
/* item data passed to LVN_GETDISPINFOA */
static LVITEMA g_itema;
static HWND subclass_editbox(HWND hwndListview); static HWND subclass_editbox(HWND hwndListview);
...@@ -366,6 +368,12 @@ static LRESULT WINAPI parent_wnd_proc(HWND hwnd, UINT message, WPARAM wParam, LP ...@@ -366,6 +368,12 @@ static LRESULT WINAPI parent_wnd_proc(HWND hwnd, UINT message, WPARAM wParam, LP
nmlv->iItem, nmlv->uNewState, nmlv->uOldState, nmlv->uChanged); nmlv->iItem, nmlv->uNewState, nmlv->uOldState, nmlv->uChanged);
} }
break; break;
case LVN_GETDISPINFOA:
{
NMLVDISPINFOA *dispinfo = (NMLVDISPINFOA*)lParam;
g_itema = dispinfo->item;
}
break;
case NM_HOVER: case NM_HOVER:
if (g_block_hover) return 1; if (g_block_hover) return 1;
break; break;
...@@ -1187,24 +1195,25 @@ static void test_items(void) ...@@ -1187,24 +1195,25 @@ static void test_items(void)
static void test_columns(void) static void test_columns(void)
{ {
HWND hwnd, hwndheader; HWND hwnd, hwndheader;
LVCOLUMN column; LVCOLUMNA column;
DWORD rc; LVITEMA item;
INT order[2]; INT order[2];
CHAR buff[5];
DWORD rc;
hwnd = CreateWindowEx(0, "SysListView32", "foo", LVS_REPORT, hwnd = CreateWindowExA(0, "SysListView32", "foo", LVS_REPORT,
10, 10, 100, 200, hwndparent, NULL, NULL, NULL); 10, 10, 100, 200, hwndparent, NULL, NULL, NULL);
ok(hwnd != NULL, "failed to create listview window\n"); ok(hwnd != NULL, "failed to create listview window\n");
/* Add a column with no mask */ /* Add a column with no mask */
memset(&column, 0xcc, sizeof(column)); memset(&column, 0xcc, sizeof(column));
column.mask = 0; column.mask = 0;
rc = ListView_InsertColumn(hwnd, 0, &column); rc = SendMessageA(hwnd, LVM_INSERTCOLUMNA, 0, (LPARAM)&column);
ok(rc==0, "Inserting column with no mask failed with %d\n", rc); ok(rc == 0, "Inserting column with no mask failed with %d\n", rc);
/* Check its width */ /* Check its width */
rc = ListView_GetColumnWidth(hwnd, 0); rc = SendMessageA(hwnd, LVM_GETCOLUMNWIDTH, 0, 0);
ok(rc==10 || ok(rc == 10 || broken(rc == 0) /* win9x */,
broken(rc==0), /* win9x */
"Inserting column with no mask failed to set width to 10 with %d\n", rc); "Inserting column with no mask failed to set width to 10 with %d\n", rc);
DestroyWindow(hwnd); DestroyWindow(hwnd);
...@@ -1216,24 +1225,43 @@ static void test_columns(void) ...@@ -1216,24 +1225,43 @@ static void test_columns(void)
memset(&column, 0, sizeof(column)); memset(&column, 0, sizeof(column));
column.mask = LVCF_WIDTH; column.mask = LVCF_WIDTH;
column.cx = 100; column.cx = 100;
rc = ListView_InsertColumn(hwnd, 0, &column); rc = SendMessageA(hwnd, LVM_INSERTCOLUMNA, 0, (LPARAM)&column);
ok(rc == 0, "Inserting column failed with %d\n", rc); ok(rc == 0, "Inserting column failed with %d\n", rc);
column.cx = 200; column.cx = 200;
rc = ListView_InsertColumn(hwnd, 1, &column); rc = SendMessageA(hwnd, LVM_INSERTCOLUMNA, 1, (LPARAM)&column);
ok(rc == 1, "Inserting column failed with %d\n", rc); ok(rc == 1, "Inserting column failed with %d\n", rc);
flush_sequences(sequences, NUM_MSG_SEQUENCES); flush_sequences(sequences, NUM_MSG_SEQUENCES);
rc = SendMessage(hwnd, LVM_GETCOLUMNORDERARRAY, 2, (LPARAM)&order); rc = SendMessageA(hwnd, LVM_GETCOLUMNORDERARRAY, 2, (LPARAM)&order);
ok(rc != 0, "Expected LVM_GETCOLUMNORDERARRAY to succeed\n"); ok(rc == 1, "Expected LVM_GETCOLUMNORDERARRAY to succeed\n");
ok(order[0] == 0, "Expected order 0, got %d\n", order[0]); ok(order[0] == 0, "Expected order 0, got %d\n", order[0]);
ok(order[1] == 1, "Expected order 1, got %d\n", order[1]); ok(order[1] == 1, "Expected order 1, got %d\n", order[1]);
ok_sequence(sequences, LISTVIEW_SEQ_INDEX, listview_getorderarray_seq, "get order array", FALSE); ok_sequence(sequences, LISTVIEW_SEQ_INDEX, listview_getorderarray_seq, "get order array", FALSE);
/* after column added subitem is considered as present */
insert_item(hwnd, 0);
flush_sequences(sequences, NUM_MSG_SEQUENCES);
item.pszText = buff;
item.cchTextMax = sizeof(buff);
item.iItem = 0;
item.iSubItem = 1;
item.mask = LVIF_TEXT;
memset(&g_itema, 0, sizeof(g_itema));
rc = SendMessageA(hwnd, LVM_GETITEMA, 0, (LPARAM)&item);
ok(rc == 1, "got %d\n", rc);
ok(g_itema.iSubItem == 1, "got %d\n", g_itema.iSubItem);
ok_sequence(sequences, PARENT_SEQ_INDEX, single_getdispinfo_parent_seq,
"get subitem text after column added", FALSE);
DestroyWindow(hwnd); DestroyWindow(hwnd);
} }
/* test setting imagelist between WM_NCCREATE and WM_CREATE */ /* test setting imagelist between WM_NCCREATE and WM_CREATE */
static WNDPROC listviewWndProc; static WNDPROC listviewWndProc;
static HIMAGELIST test_create_imagelist; static HIMAGELIST test_create_imagelist;
...@@ -3389,7 +3417,6 @@ static void test_getitemrect(void) ...@@ -3389,7 +3417,6 @@ static void test_getitemrect(void)
expect(2 + 16, rect.left); expect(2 + 16, rect.left);
expect(34, rect.right); expect(34, rect.right);
DestroyWindow(hwnd); DestroyWindow(hwnd);
} }
......
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