Bugfix: Don’t attach tiling containers to floating containers
This bug happened when there were only floating containers on a workspace and a new tiling window was to be opened.
This commit is contained in:
parent
f53fafe100
commit
09b5b17830
22
src/con.c
22
src/con.c
|
@ -70,14 +70,24 @@ Con *con_new(Con *parent) {
|
||||||
*/
|
*/
|
||||||
void con_attach(Con *con, Con *parent) {
|
void con_attach(Con *con, Con *parent) {
|
||||||
con->parent = parent;
|
con->parent = parent;
|
||||||
Con *current = TAILQ_FIRST(&(parent->focus_head));
|
Con *loop;
|
||||||
|
Con *current = NULL;
|
||||||
|
|
||||||
if (current == TAILQ_END(&(parent->focus_head)))
|
/* Get the first tiling container in focus stack */
|
||||||
TAILQ_INSERT_TAIL(&(parent->nodes_head), con, nodes);
|
TAILQ_FOREACH(loop, &(parent->focus_head), focused) {
|
||||||
else {
|
if (loop->type == CT_FLOATING_CON)
|
||||||
DLOG("inserting after\n");
|
continue;
|
||||||
TAILQ_INSERT_AFTER(&(parent->nodes_head), current, con, nodes);
|
current = loop;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Insert the container after the tiling container, if found */
|
||||||
|
if (current) {
|
||||||
|
DLOG("Inserting con = %p after last focused tiling con %p\n",
|
||||||
|
con, current);
|
||||||
|
TAILQ_INSERT_AFTER(&(parent->nodes_head), current, con, nodes);
|
||||||
|
} else TAILQ_INSERT_TAIL(&(parent->nodes_head), con, nodes);
|
||||||
|
|
||||||
/* We insert to the TAIL because con_focus() will correct this.
|
/* We insert to the TAIL because con_focus() will correct this.
|
||||||
* This way, we have the option to insert Cons without having
|
* This way, we have the option to insert Cons without having
|
||||||
* to focus them. */
|
* to focus them. */
|
||||||
|
|
|
@ -104,6 +104,10 @@ Con *tree_open_con(Con *con) {
|
||||||
* the new container needs to be opened as a leaf of the workspace. */
|
* the new container needs to be opened as a leaf of the workspace. */
|
||||||
if (con->type == CT_OUTPUT)
|
if (con->type == CT_OUTPUT)
|
||||||
con = focused;
|
con = focused;
|
||||||
|
/* If the currently focused container is a floating container, we
|
||||||
|
* attach the new container to the workspace */
|
||||||
|
if (con->type == CT_FLOATING_CON)
|
||||||
|
con = con->parent;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(con != NULL);
|
assert(con != NULL);
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
#!perl
|
||||||
|
# vim:ts=4:sw=4:expandtab
|
||||||
|
# Regression test: New windows were attached to the container of a floating window
|
||||||
|
# if only a floating window is present on the workspace.
|
||||||
|
|
||||||
|
use i3test tests => 7;
|
||||||
|
use X11::XCB qw(:all);
|
||||||
|
use Time::HiRes qw(sleep);
|
||||||
|
|
||||||
|
BEGIN {
|
||||||
|
use_ok('X11::XCB::Window');
|
||||||
|
}
|
||||||
|
|
||||||
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
|
||||||
|
my $tmp = get_unused_workspace();
|
||||||
|
$i3->command("workspace $tmp")->recv;
|
||||||
|
|
||||||
|
#############################################################################
|
||||||
|
# 1: open a floating window, get it mapped
|
||||||
|
#############################################################################
|
||||||
|
|
||||||
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
|
# Create a floating window
|
||||||
|
my $window = $x->root->create_child(
|
||||||
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
|
rect => [ 0, 0, 30, 30],
|
||||||
|
background_color => '#C0C0C0',
|
||||||
|
# replace the type with 'utility' as soon as the coercion works again in X11::XCB
|
||||||
|
window_type => $x->atom(name => '_NET_WM_WINDOW_TYPE_UTILITY'),
|
||||||
|
);
|
||||||
|
|
||||||
|
isa_ok($window, 'X11::XCB::Window');
|
||||||
|
|
||||||
|
$window->map;
|
||||||
|
|
||||||
|
sleep 0.25;
|
||||||
|
|
||||||
|
ok($window->mapped, 'Window is mapped');
|
||||||
|
|
||||||
|
my $ws = get_ws($tmp);
|
||||||
|
my ($nodes, $focus) = get_ws_content($tmp);
|
||||||
|
|
||||||
|
is(@{$ws->{floating_nodes}}, 1, 'one floating node');
|
||||||
|
is(@{$nodes}, 0, 'no tiling nodes');
|
||||||
|
|
||||||
|
# Create a tiling window
|
||||||
|
my $twindow = $x->root->create_child(
|
||||||
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
|
rect => [ 0, 0, 30, 30],
|
||||||
|
background_color => '#C0C0C0',
|
||||||
|
);
|
||||||
|
|
||||||
|
isa_ok($twindow, 'X11::XCB::Window');
|
||||||
|
|
||||||
|
$twindow->map;
|
||||||
|
|
||||||
|
sleep 0.25;
|
||||||
|
|
||||||
|
($nodes, $focus) = get_ws_content($tmp);
|
||||||
|
|
||||||
|
is(@{$nodes}, 1, 'one tiling node');
|
Loading…
Reference in New Issue