Commit a73afbcb authored by Christopher Thielen's avatar Christopher Thielen Committed by Michael Stefaniuc

user32: A window may be notified with WM_CAPTURECHANGED about itself if…

user32: A window may be notified with WM_CAPTURECHANGED about itself if SetCapture() is called twice. Signed-off-by: 's avatarChristopher Thielen <cthielen@gmail.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org> (cherry picked from commit 9bb87cc7) Signed-off-by: 's avatarMichael Stefaniuc <mstefani@winehq.org>
parent 9a80865b
......@@ -108,7 +108,7 @@ BOOL set_capture_window( HWND hwnd, UINT gui_flags, HWND *prev_ret )
{
USER_Driver->pSetCapture( hwnd, gui_flags );
if (previous && previous != hwnd)
if (previous)
SendMessageW( previous, WM_CAPTURECHANGED, 0, (LPARAM)hwnd );
if (prev_ret) *prev_ret = previous;
......
......@@ -14906,6 +14906,33 @@ else
flush_sequence();
}
static const struct message DoubleSetCaptureSeq[] =
{
{ WM_CAPTURECHANGED, sent },
{ 0 }
};
static void test_DoubleSetCapture(void)
{
HWND hwnd;
hwnd = CreateWindowExA(0, "TestWindowClass", "Test DoubleSetCapture",
WS_OVERLAPPEDWINDOW | WS_VISIBLE,
100, 100, 200, 200, 0, 0, 0, NULL);
ok (hwnd != 0, "Failed to create overlapped window\n");
ShowWindow( hwnd, SW_SHOW );
UpdateWindow( hwnd );
flush_events();
flush_sequence();
SetCapture( hwnd );
SetCapture( hwnd );
ok_sequence(DoubleSetCaptureSeq, "SetCapture( hwnd ) twice", FALSE);
DestroyWindow(hwnd);
}
static void init_funcs(void)
{
HMODULE hKernel32 = GetModuleHandleA("kernel32.dll");
......@@ -15045,6 +15072,7 @@ START_TEST(msg)
test_layered_window();
test_TrackPopupMenu();
test_TrackPopupMenuEmpty();
test_DoubleSetCapture();
/* keep it the last test, under Windows it tends to break the tests
* which rely on active/foreground windows being correct.
*/
......
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