summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/events.c8
-rw-r--r--src/list.c11
2 files changed, 10 insertions, 9 deletions
diff --git a/src/events.c b/src/events.c
index 29a43f5..16739f9 100644
--- a/src/events.c
+++ b/src/events.c
@@ -66,6 +66,10 @@ cleanup_frame (rp_window_frame *frame)
win = find_window_other ();
if (win)
{
+ maximize (win);
+ unhide_transient_for (win);
+ unhide_window (win);
+
if (is_transient_ancestor (frame->win, win))
{
hide_transient_for_between (frame->win, win);
@@ -76,10 +80,6 @@ cleanup_frame (rp_window_frame *frame)
}
frame->win = win;
-
- maximize (frame->win);
- unhide_transient_for (frame->win);
- unhide_window (frame->win);
}
else
{
diff --git a/src/list.c b/src/list.c
index 6c2bd36..b3f97bd 100644
--- a/src/list.c
+++ b/src/list.c
@@ -510,6 +510,12 @@ set_active_window (rp_window *win)
if (last_win) PRINT_DEBUG ("last window: %s\n", last_win->name);
PRINT_DEBUG ("new window: %s\n", win->name);
+ /* Make sure the window comes up full screen */
+ unhide_transient_for (win);
+ maximize (win);
+ unhide_window (win);
+
+ /* Hide the last window and its transients_fors */
if (is_transient_ancestor (win, last_win))
{
/* Do nothing if last_win is a transient since it should stay visible */
@@ -529,11 +535,6 @@ set_active_window (rp_window *win)
}
}
- /* Make sure the window comes up full screen */
- unhide_transient_for (win);
- maximize (win);
- unhide_window (win);
-
give_window_focus (win, last_win);
/* Make sure the program bar is always on the top */