diff --git a/src/core/window-private.h b/src/core/window-private.h index 1e188d0c7..1c1215972 100644 --- a/src/core/window-private.h +++ b/src/core/window-private.h @@ -669,6 +669,9 @@ void meta_window_resize_frame_with_gravity (MetaWindow *window, int h, MetaGravity gravity); +gboolean meta_window_should_be_showing_on_workspace (MetaWindow *window, + MetaWorkspace *workspace); + /* Return whether the window should be currently mapped */ gboolean meta_window_should_be_showing (MetaWindow *window); diff --git a/src/core/window.c b/src/core/window.c index 2ce0b6687..e1ac1f7eb 100644 --- a/src/core/window.c +++ b/src/core/window.c @@ -1691,10 +1691,9 @@ meta_window_showing_on_its_workspace (MetaWindow *window) } gboolean -meta_window_should_be_showing (MetaWindow *window) +meta_window_should_be_showing_on_workspace (MetaWindow *window, + MetaWorkspace *workspace) { - MetaWorkspaceManager *workspace_manager = window->display->workspace_manager; - #ifdef HAVE_WAYLAND if (window->client_type == META_WINDOW_CLIENT_TYPE_WAYLAND) { @@ -1709,11 +1708,20 @@ meta_window_should_be_showing (MetaWindow *window) return FALSE; /* Windows should be showing if they're located on the - * active workspace and they're showing on their own workspace. */ - return (meta_window_located_on_workspace (window, workspace_manager->active_workspace) && + * workspace and they're showing on their own workspace. */ + return (meta_window_located_on_workspace (window, workspace) && meta_window_showing_on_its_workspace (window)); } +gboolean +meta_window_should_be_showing (MetaWindow *window) +{ + MetaWorkspaceManager *workspace_manager = window->display->workspace_manager; + MetaWorkspace *active_workspace = workspace_manager->active_workspace; + + return meta_window_should_be_showing_on_workspace (window, active_workspace); +} + static void implement_showing (MetaWindow *window, gboolean showing) diff --git a/src/core/workspace.c b/src/core/workspace.c index 2c091768e..a70791b46 100644 --- a/src/core/workspace.c +++ b/src/core/workspace.c @@ -1436,8 +1436,7 @@ is_focusable (MetaWindow *window, window->unmaps_pending == 0 && window->type != META_WINDOW_DOCK && meta_window_is_focusable (window) && - meta_window_located_on_workspace (window, workspace) && - meta_window_showing_on_its_workspace (window); + meta_window_should_be_showing_on_workspace (window, workspace); } static gboolean