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

comctl32/listview: Fix find using partial string logic.

parent 90c4abe8
...@@ -5949,12 +5949,13 @@ again: ...@@ -5949,12 +5949,13 @@ again:
else else
continue; continue;
} }
if (lvItem.mask & LVIF_TEXT) if (lvItem.mask & LVIF_TEXT)
{ {
if (lpFindInfo->flags & LVFI_PARTIAL) if (lpFindInfo->flags & LVFI_PARTIAL)
{ {
if (strstrW(lvItem.pszText, lpFindInfo->psz) == NULL) continue; WCHAR *p = strstrW(lvItem.pszText, lpFindInfo->psz);
if (!p || p != lvItem.pszText) continue;
} }
else else
{ {
...@@ -5963,7 +5964,7 @@ again: ...@@ -5963,7 +5964,7 @@ again:
} }
if (!bNearest) return nItem; if (!bNearest) return nItem;
/* This is very inefficient. To do a good job here, /* This is very inefficient. To do a good job here,
* we need a sorted array of (x,y) item positions */ * we need a sorted array of (x,y) item positions */
LISTVIEW_GetItemOrigin(infoPtr, nItem, &Position); LISTVIEW_GetItemOrigin(infoPtr, nItem, &Position);
......
...@@ -4023,7 +4023,7 @@ static void test_LVS_EX_TRANSPARENTBKGND(void) ...@@ -4023,7 +4023,7 @@ static void test_LVS_EX_TRANSPARENTBKGND(void)
DestroyWindow(hwnd); DestroyWindow(hwnd);
} }
static void test_ApproximateViewRect(void) static void test_approximate_viewrect(void)
{ {
HWND hwnd; HWND hwnd;
DWORD ret; DWORD ret;
...@@ -4097,6 +4097,40 @@ static void test_ApproximateViewRect(void) ...@@ -4097,6 +4097,40 @@ static void test_ApproximateViewRect(void)
DestroyWindow(hwnd); DestroyWindow(hwnd);
} }
static void test_finditem(void)
{
LVFINDINFOA fi;
static char f[5];
HWND hwnd;
DWORD r;
hwnd = create_listview_control(0);
insert_item(hwnd, 0);
memset(&fi, 0, sizeof(fi));
/* full string search, inserted text was "foo" */
strcpy(f, "foo");
fi.flags = LVFI_STRING;
fi.psz = f;
r = SendMessage(hwnd, LVM_FINDITEMA, -1, (LPARAM)&fi);
expect(0, r);
/* partial string search, inserted text was "foo" */
strcpy(f, "fo");
fi.flags = LVFI_STRING | LVFI_PARTIAL;
fi.psz = f;
r = SendMessage(hwnd, LVM_FINDITEMA, -1, (LPARAM)&fi);
expect(0, r);
/* partial string search, part after start char */
strcpy(f, "oo");
fi.flags = LVFI_STRING | LVFI_PARTIAL;
fi.psz = f;
r = SendMessage(hwnd, LVM_FINDITEMA, -1, (LPARAM)&fi);
expect(-1, r);
DestroyWindow(hwnd);
}
START_TEST(listview) START_TEST(listview)
{ {
HMODULE hComctl32; HMODULE hComctl32;
...@@ -4154,7 +4188,8 @@ START_TEST(listview) ...@@ -4154,7 +4188,8 @@ START_TEST(listview)
test_indentation(); test_indentation();
test_getitemspacing(); test_getitemspacing();
test_getcolumnwidth(); test_getcolumnwidth();
test_ApproximateViewRect(); test_approximate_viewrect();
test_finditem();
if (!load_v6_module(&ctx_cookie, &hCtx)) if (!load_v6_module(&ctx_cookie, &hCtx))
{ {
......
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