Commit c1297ac0 authored by Alexandre Julliard's avatar Alexandre Julliard

winex11: Only take managed popups into account when deciding whether to make a window managed.

parent c4cf9024
...@@ -159,12 +159,15 @@ struct has_popup_result ...@@ -159,12 +159,15 @@ struct has_popup_result
BOOL found; BOOL found;
}; };
static BOOL CALLBACK has_popup( HWND hwnd, LPARAM lparam ) static BOOL CALLBACK has_managed_popup( HWND hwnd, LPARAM lparam )
{ {
struct has_popup_result *result = (struct has_popup_result *)lparam; struct has_popup_result *result = (struct has_popup_result *)lparam;
struct x11drv_win_data *data;
if (hwnd == result->hwnd) return FALSE; /* popups are always above owner */ if (hwnd == result->hwnd) return FALSE; /* popups are always above owner */
result->found = (GetWindow( hwnd, GW_OWNER ) == result->hwnd); if (!(data = X11DRV_get_win_data( hwnd ))) return TRUE;
if (GetWindow( hwnd, GW_OWNER ) != result->hwnd) return TRUE;
result->found = data->managed;
return !result->found; return !result->found;
} }
...@@ -174,7 +177,7 @@ static BOOL has_owned_popups( HWND hwnd ) ...@@ -174,7 +177,7 @@ static BOOL has_owned_popups( HWND hwnd )
result.hwnd = hwnd; result.hwnd = hwnd;
result.found = FALSE; result.found = FALSE;
EnumWindows( has_popup, (LPARAM)&result ); EnumWindows( has_managed_popup, (LPARAM)&result );
return result.found; return result.found;
} }
......
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