]> git.sur5r.net Git - i3/i3/commitdiff
When leaving fullscreen, set focus to con which was opened during fullscreen (+testca...
authorMichael Stapelberg <michael@stapelberg.de>
Sun, 6 Mar 2011 23:06:27 +0000 (00:06 +0100)
committerMichael Stapelberg <michael@stapelberg.de>
Sun, 6 Mar 2011 23:06:27 +0000 (00:06 +0100)
src/manage.c
testcases/t/56-fullscreen-focus.t [new file with mode: 0644]
testcases/t/lib/i3test.pm

index 789bd8a9029a996d6b8f7318a6b2bdf3f927b470..1465457e41f5434ea3b1ba3644bf4e5b21629905 100644 (file)
@@ -244,6 +244,12 @@ void manage_window(xcb_window_t window, xcb_get_window_attributes_cookie_t cooki
         else DLOG("dock, not focusing\n");
     } else {
         DLOG("fs = %p, ws = %p, not focusing\n", fs, ws);
+        /* Insert the new container in focus stack *after* the currently
+         * focused (fullscreen) con. This way, the new container will be
+         * focused after we return from fullscreen mode */
+        Con *first = TAILQ_FIRST(&(nc->parent->focus_head));
+        TAILQ_REMOVE(&(nc->parent->focus_head), nc, focused);
+        TAILQ_INSERT_AFTER(&(nc->parent->focus_head), first, nc, focused);
     }
 
     /* set floating if necessary */
diff --git a/testcases/t/56-fullscreen-focus.t b/testcases/t/56-fullscreen-focus.t
new file mode 100644 (file)
index 0000000..7d8b16c
--- /dev/null
@@ -0,0 +1,65 @@
+#!perl
+# vim:ts=4:sw=4:expandtab
+#
+# Test if new containers get focused when there is a fullscreen container at
+# the time of launching the new one.
+#
+use X11::XCB qw(:all);
+use Time::HiRes qw(sleep);
+use i3test;
+
+BEGIN {
+    use_ok('X11::XCB::Window');
+}
+
+my $x = X11::XCB::Connection->new;
+my $i3 = i3("/tmp/nestedcons");
+
+my $tmp = get_unused_workspace;
+cmd "workspace $tmp";
+
+#####################################################################
+# open the left window
+#####################################################################
+
+my $left = open_standard_window($x, '#ff0000');
+
+is($x->input_focus, $left->id, 'left window focused');
+
+diag("left = " . $left->id);
+
+#####################################################################
+# Open the right window
+#####################################################################
+
+my $right = open_standard_window($x, '#00ff00');
+
+diag("right = " . $right->id);
+
+#####################################################################
+# Set the right window to fullscreen
+#####################################################################
+cmd 'nop setting fullscreen';
+cmd 'fullscreen';
+
+#####################################################################
+# Open a third window
+#####################################################################
+
+my $third = open_standard_window($x, '#0000ff');
+
+diag("third = " . $third->id);
+
+# move the fullscreen window to a different ws
+
+my $tmp2 = get_unused_workspace;
+
+cmd "move workspace $tmp2";
+
+# verify that the third window has the focus
+
+sleep 0.25;
+
+is($x->input_focus, $third->id, 'third window focused');
+
+done_testing;
index b9d168d6d91ba0577e30ed4533bb39346add4a0e..87a3498124c482aa9c9865d366eb13d2e956798b 100644 (file)
@@ -9,6 +9,7 @@ use X11::XCB qw(:all);
 use AnyEvent::I3;
 use List::Util qw(first);
 use List::MoreUtils qw(lastval);
+use Time::HiRes qw(sleep);
 use v5.10;
 
 use Exporter ();
@@ -41,12 +42,14 @@ use warnings;
 }
 
 sub open_standard_window {
-    my ($x) = @_;
+    my ($x, $color) = @_;
+
+    $color ||= '#c0c0c0';
 
     my $window = $x->root->create_child(
         class => WINDOW_CLASS_INPUT_OUTPUT,
         rect => [ 0, 0, 30, 30 ],
-        background_color => '#C0C0C0',
+        background_color => $color,
     );
 
     $window->name('Window ' . counter_window());