Fix identification of CSD windows when checking whether to force fullscreen
We try to exempt CSD windows from being forced fullscreen if they are undecorated and the size of the screen; however, we also catch almost all windows that *do* need to be forced fullscreen in this check, since they also have decorations turned off. Identify actual CSD windows by checking whether _GTK_FRAME_EXTENTS is set - GTK+ will always set this on CSD windows even if they have no invisible borders or shadows at the current time. We explicitly turn off the legacy-fullscreen check for native wayland windows so we don't start legacy-fullscreening them if the new meta_window_is_client_decorated() is later made more accurate. https://bugzilla.gnome.org/show_bug.cgi?id=723029
This commit is contained in:
parent
40c15f6e2a
commit
2cf80bc647
@ -425,8 +425,9 @@ setup_constraint_info (ConstraintInfo *info,
|
|||||||
* the monitor.
|
* the monitor.
|
||||||
*/
|
*/
|
||||||
if (meta_prefs_get_force_fullscreen() &&
|
if (meta_prefs_get_force_fullscreen() &&
|
||||||
|
window->client_type != META_WINDOW_CLIENT_TYPE_WAYLAND &&
|
||||||
!window->hide_titlebar_when_maximized &&
|
!window->hide_titlebar_when_maximized &&
|
||||||
window->decorated &&
|
(window->decorated || !meta_window_is_client_decorated (window)) &&
|
||||||
meta_rectangle_equal (new, &monitor_info->rect) &&
|
meta_rectangle_equal (new, &monitor_info->rect) &&
|
||||||
window->has_fullscreen_func &&
|
window->has_fullscreen_func &&
|
||||||
!window->fullscreen)
|
!window->fullscreen)
|
||||||
|
@ -751,4 +751,6 @@ void meta_window_activate_full (MetaWindow *window,
|
|||||||
MetaClientType source_indication,
|
MetaClientType source_indication,
|
||||||
MetaWorkspace *workspace);
|
MetaWorkspace *workspace);
|
||||||
|
|
||||||
|
gboolean meta_window_is_client_decorated (MetaWindow *window);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -8856,6 +8856,34 @@ meta_window_same_application (MetaWindow *window,
|
|||||||
group==other_group;
|
group==other_group;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_window_is_client_decorated:
|
||||||
|
*
|
||||||
|
* Check if if the window has decorations drawn by the client.
|
||||||
|
* (window->decorated refers only to whether we should add decorations)
|
||||||
|
*/
|
||||||
|
gboolean
|
||||||
|
meta_window_is_client_decorated (MetaWindow *window)
|
||||||
|
{
|
||||||
|
if (window->client_type == META_WINDOW_CLIENT_TYPE_WAYLAND)
|
||||||
|
{
|
||||||
|
/* Assume all Wayland clients draw decorations - not strictly
|
||||||
|
* true but good enough for current purposes.
|
||||||
|
*/
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* Currently the implementation here is hackish -
|
||||||
|
* has_custom_frame_extents() is set if _GTK_FRAME_EXTENTS is set
|
||||||
|
* to any value even 0. GTK+ always sets _GTK_FRAME_EXTENTS for
|
||||||
|
* client-side-decorated window, even if the value is 0 because
|
||||||
|
* the window is maxized and has no invisible borders or shadows.
|
||||||
|
*/
|
||||||
|
return window->has_custom_frame_extents;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
meta_window_refresh_resize_popup (MetaWindow *window)
|
meta_window_refresh_resize_popup (MetaWindow *window)
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user