do not match docks in config and command criteria (#2340)
This commit is contained in:
parent
655ed0ba27
commit
1437271e65
|
@ -480,7 +480,7 @@ void dump_node(yajl_gen gen, struct Con *con, bool inplace_restart) {
|
|||
if (match->restart_mode)
|
||||
continue;
|
||||
y(map_open);
|
||||
if (match->dock != -1) {
|
||||
if (match->dock != M_DONTCHECK) {
|
||||
ystr("dock");
|
||||
y(integer, match->dock);
|
||||
ystr("insert_where");
|
||||
|
|
|
@ -48,6 +48,7 @@ static int json_start_map(void *ctx) {
|
|||
LOG("creating new swallow\n");
|
||||
current_swallow = smalloc(sizeof(Match));
|
||||
match_init(current_swallow);
|
||||
current_swallow->dock = M_DONTCHECK;
|
||||
TAILQ_INSERT_TAIL(&(json_node->swallow_head), current_swallow, matches);
|
||||
swallow_is_empty = true;
|
||||
} else {
|
||||
|
|
|
@ -27,7 +27,6 @@
|
|||
*/
|
||||
void match_init(Match *match) {
|
||||
memset(match, 0, sizeof(Match));
|
||||
match->dock = M_DONTCHECK;
|
||||
match->urgent = U_DONTCHECK;
|
||||
/* we use this as the placeholder value for "not set". */
|
||||
match->window_type = UINT32_MAX;
|
||||
|
@ -53,7 +52,7 @@ bool match_is_empty(Match *match) {
|
|||
match->id == XCB_NONE &&
|
||||
match->window_type == UINT32_MAX &&
|
||||
match->con_id == NULL &&
|
||||
match->dock == -1 &&
|
||||
match->dock == M_NODOCK &&
|
||||
match->floating == M_ANY);
|
||||
}
|
||||
|
||||
|
|
|
@ -240,6 +240,7 @@ static void open_placeholder_window(Con *con) {
|
|||
/* create temporary id swallow to match the placeholder */
|
||||
Match *temp_id = smalloc(sizeof(Match));
|
||||
match_init(temp_id);
|
||||
temp_id->dock = M_DONTCHECK;
|
||||
temp_id->id = placeholder;
|
||||
TAILQ_INSERT_HEAD(&(con->swallow_head), temp_id, matches);
|
||||
}
|
||||
|
|
|
@ -0,0 +1,71 @@
|
|||
#!perl
|
||||
# vim:ts=4:sw=4:expandtab
|
||||
#
|
||||
# Please read the following documents before working on tests:
|
||||
# • http://build.i3wm.org/docs/testsuite.html
|
||||
# (or docs/testsuite)
|
||||
#
|
||||
# • http://build.i3wm.org/docs/lib-i3test.html
|
||||
# (alternatively: perldoc ./testcases/lib/i3test.pm)
|
||||
#
|
||||
# • http://build.i3wm.org/docs/ipc.html
|
||||
# (or docs/ipc)
|
||||
#
|
||||
# • http://onyxneon.com/books/modern_perl/modern_perl_a4.pdf
|
||||
# (unless you are already familiar with Perl)
|
||||
#
|
||||
# Verifies that command or config criteria does not match dock clients
|
||||
# Bug still in: 4.12-38-ge690e3d
|
||||
use i3test i3_autostart => 0;
|
||||
|
||||
my $config = <<EOT;
|
||||
# i3 config file (v4)
|
||||
for_window [class="dock"] move workspace current
|
||||
EOT
|
||||
|
||||
my $pid = launch_with_config($config);
|
||||
|
||||
my $ws = fresh_workspace();
|
||||
|
||||
|
||||
## command criteria should not match dock windows
|
||||
open_window({
|
||||
window_type => $x->atom(name => '_NET_WM_WINDOW_TYPE_DOCK'),
|
||||
wm_class => "x"
|
||||
});
|
||||
|
||||
is(get_dock_clients, 1, "created one docked client");
|
||||
is_num_children($ws, 0, 'no container on the current workspace');
|
||||
|
||||
cmd '[class="^x$"] move workspace current';
|
||||
|
||||
does_i3_live
|
||||
is(get_dock_clients, 1, "one docked client after move");
|
||||
is_num_children($ws, 0, 'no container on the current workspace');
|
||||
|
||||
cmd '[class="^x$"] fullscreen';
|
||||
|
||||
does_i3_live
|
||||
is(get_dock_clients, 1, "one docked client after fullscreen");
|
||||
is_num_children($ws, 0, 'no container on the current workspace');
|
||||
|
||||
cmd '[class="^x$"] kill';
|
||||
|
||||
does_i3_live
|
||||
is(get_dock_clients, 1, "one docked client after kill");
|
||||
is_num_children($ws, 0, 'no container on the current workspace');
|
||||
|
||||
|
||||
## config criteria should not match dock windows
|
||||
open_window({
|
||||
window_type => $x->atom(name => '_NET_WM_WINDOW_TYPE_DOCK'),
|
||||
wm_class => "dock"
|
||||
});
|
||||
|
||||
does_i3_live
|
||||
is(get_dock_clients, 2, "created second docked client");
|
||||
is_num_children($ws, 0, 'no container on the current workspace');
|
||||
|
||||
|
||||
exit_gracefully($pid);
|
||||
done_testing;
|
Loading…
Reference in New Issue