Merge branch 'fix-multi-for_window' into next
This commit is contained in:
commit
c43288a249
|
@ -685,6 +685,11 @@ matchend:
|
||||||
;
|
;
|
||||||
|
|
||||||
criteria:
|
criteria:
|
||||||
|
criteria criterion
|
||||||
|
| criterion
|
||||||
|
;
|
||||||
|
|
||||||
|
criterion:
|
||||||
TOK_CLASS '=' STR
|
TOK_CLASS '=' STR
|
||||||
{
|
{
|
||||||
printf("criteria: class = %s\n", $3);
|
printf("criteria: class = %s\n", $3);
|
||||||
|
|
|
@ -1,7 +1,3 @@
|
||||||
for_window [class="borderless"] border none
|
|
||||||
for_window [title="special borderless title"] border none
|
|
||||||
for_window [title="special mark title"] border none, mark bleh
|
|
||||||
|
|
||||||
# ISO 10646 = Unicode
|
# ISO 10646 = Unicode
|
||||||
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
||||||
|
|
||||||
|
|
|
@ -1,14 +1,19 @@
|
||||||
#!perl
|
#!perl
|
||||||
# vim:ts=4:sw=4:expandtab
|
# vim:ts=4:sw=4:expandtab
|
||||||
|
# !NO_I3_INSTANCE! will prevent complete-run.pl from starting i3
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
use X11::XCB qw(:all);
|
use X11::XCB qw(:all);
|
||||||
use X11::XCB::Connection;
|
use X11::XCB::Connection;
|
||||||
use i3test;
|
use i3test;
|
||||||
|
use Cwd qw(abs_path);
|
||||||
|
use Proc::Background;
|
||||||
|
use File::Temp qw(tempfile tempdir);
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $tmp = fresh_workspace;
|
# assuming we are run by complete-run.pl
|
||||||
|
my $i3_path = abs_path("../i3");
|
||||||
|
|
||||||
##############################################################
|
##############################################################
|
||||||
# 1: test the following directive:
|
# 1: test the following directive:
|
||||||
|
@ -18,6 +23,25 @@ my $tmp = fresh_workspace;
|
||||||
# "borderless" (should get no border)
|
# "borderless" (should get no border)
|
||||||
##############################################################
|
##############################################################
|
||||||
|
|
||||||
|
my $socketpath = File::Temp::tempnam('/tmp', 'i3-test-socket-');
|
||||||
|
|
||||||
|
my ($fh, $tmpfile) = tempfile();
|
||||||
|
say $fh "# i3 config file (v4)";
|
||||||
|
say $fh "font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1";
|
||||||
|
say $fh "ipc-socket $socketpath";
|
||||||
|
say $fh q|for_window [class="borderless"] border none|;
|
||||||
|
close($fh);
|
||||||
|
|
||||||
|
diag("Starting i3");
|
||||||
|
my $i3cmd = "exec " . abs_path("../i3") . " -V -d all --disable-signalhandler -c $tmpfile >/dev/null 2>/dev/null";
|
||||||
|
my $process = Proc::Background->new($i3cmd);
|
||||||
|
sleep 1;
|
||||||
|
|
||||||
|
# force update of the cached socket path in lib/i3test
|
||||||
|
get_socket_path(0);
|
||||||
|
|
||||||
|
my $tmp = fresh_workspace;
|
||||||
|
|
||||||
my $window = $x->root->create_child(
|
my $window = $x->root->create_child(
|
||||||
class => WINDOW_CLASS_INPUT_OUTPUT,
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
rect => [ 0, 0, 30, 30 ],
|
rect => [ 0, 0, 30, 30 ],
|
||||||
|
@ -81,11 +105,31 @@ sleep 0.25;
|
||||||
@content = @{get_ws_content($tmp)};
|
@content = @{get_ws_content($tmp)};
|
||||||
cmp_ok(@content, '==', 0, 'no more nodes');
|
cmp_ok(@content, '==', 0, 'no more nodes');
|
||||||
|
|
||||||
|
exit_gracefully($process->pid);
|
||||||
|
|
||||||
##############################################################
|
##############################################################
|
||||||
# 2: match on the title, check if for_window is really executed
|
# 2: match on the title, check if for_window is really executed
|
||||||
# only once
|
# only once
|
||||||
##############################################################
|
##############################################################
|
||||||
|
|
||||||
|
($fh, $tmpfile) = tempfile();
|
||||||
|
say $fh "# i3 config file (v4)";
|
||||||
|
say $fh "font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1";
|
||||||
|
say $fh "ipc-socket $socketpath";
|
||||||
|
say $fh q|for_window [class="borderless"] border none|;
|
||||||
|
say $fh q|for_window [title="special borderless title"] border none|;
|
||||||
|
close($fh);
|
||||||
|
|
||||||
|
diag("Starting i3");
|
||||||
|
my $i3cmd = "exec " . abs_path("../i3") . " -V -d all --disable-signalhandler -c $tmpfile >/dev/null 2>/dev/null";
|
||||||
|
my $process = Proc::Background->new($i3cmd);
|
||||||
|
sleep 1;
|
||||||
|
|
||||||
|
# force update of the cached socket path in lib/i3test
|
||||||
|
get_socket_path(0);
|
||||||
|
|
||||||
|
$tmp = fresh_workspace;
|
||||||
|
|
||||||
$window = $x->root->create_child(
|
$window = $x->root->create_child(
|
||||||
class => WINDOW_CLASS_INPUT_OUTPUT,
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
rect => [ 0, 0, 30, 30 ],
|
rect => [ 0, 0, 30, 30 ],
|
||||||
|
@ -126,10 +170,31 @@ sleep 0.25;
|
||||||
@content = @{get_ws_content($tmp)};
|
@content = @{get_ws_content($tmp)};
|
||||||
cmp_ok(@content, '==', 0, 'no more nodes');
|
cmp_ok(@content, '==', 0, 'no more nodes');
|
||||||
|
|
||||||
|
exit_gracefully($process->pid);
|
||||||
|
|
||||||
##############################################################
|
##############################################################
|
||||||
# 3: match on the title, set border style *and* a mark
|
# 3: match on the title, set border style *and* a mark
|
||||||
##############################################################
|
##############################################################
|
||||||
|
|
||||||
|
($fh, $tmpfile) = tempfile();
|
||||||
|
say $fh "# i3 config file (v4)";
|
||||||
|
say $fh "font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1";
|
||||||
|
say $fh "ipc-socket $socketpath";
|
||||||
|
say $fh q|for_window [class="borderless"] border none|;
|
||||||
|
say $fh q|for_window [title="special borderless title"] border none|;
|
||||||
|
say $fh q|for_window [title="special mark title"] border none, mark bleh|;
|
||||||
|
close($fh);
|
||||||
|
|
||||||
|
diag("Starting i3");
|
||||||
|
my $i3cmd = "exec " . abs_path("../i3") . " -V -d all --disable-signalhandler -c $tmpfile >/dev/null 2>/dev/null";
|
||||||
|
my $process = Proc::Background->new($i3cmd);
|
||||||
|
sleep 1;
|
||||||
|
|
||||||
|
# force update of the cached socket path in lib/i3test
|
||||||
|
get_socket_path(0);
|
||||||
|
|
||||||
|
$tmp = fresh_workspace;
|
||||||
|
|
||||||
$window = $x->root->create_child(
|
$window = $x->root->create_child(
|
||||||
class => WINDOW_CLASS_INPUT_OUTPUT,
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
rect => [ 0, 0, 30, 30 ],
|
rect => [ 0, 0, 30, 30 ],
|
||||||
|
@ -157,4 +222,62 @@ cmd qq|[con_mark="bleh"] focus|;
|
||||||
@content = @{get_ws_content($tmp)};
|
@content = @{get_ws_content($tmp)};
|
||||||
ok($content[0]->{focused}, 'first node focused');
|
ok($content[0]->{focused}, 'first node focused');
|
||||||
|
|
||||||
|
exit_gracefully($process->pid);
|
||||||
|
|
||||||
|
##############################################################
|
||||||
|
# 4: multiple criteria for the for_window command
|
||||||
|
##############################################################
|
||||||
|
|
||||||
|
($fh, $tmpfile) = tempfile();
|
||||||
|
say $fh "# i3 config file (v4)";
|
||||||
|
say $fh "font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1";
|
||||||
|
say $fh "ipc-socket $socketpath";
|
||||||
|
say $fh q|for_window [class="borderless" title="usethis"] border none|;
|
||||||
|
close($fh);
|
||||||
|
|
||||||
|
diag("Starting i3");
|
||||||
|
my $i3cmd = "exec " . abs_path("../i3") . " -V -d all --disable-signalhandler -c $tmpfile >/tmp/a 2>/dev/null";
|
||||||
|
my $process = Proc::Background->new($i3cmd);
|
||||||
|
sleep 1;
|
||||||
|
|
||||||
|
# force update of the cached socket path in lib/i3test
|
||||||
|
get_socket_path(0);
|
||||||
|
|
||||||
|
$tmp = fresh_workspace;
|
||||||
|
|
||||||
|
$window = $x->root->create_child(
|
||||||
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
|
rect => [ 0, 0, 30, 30 ],
|
||||||
|
background_color => '#00ff00',
|
||||||
|
);
|
||||||
|
|
||||||
|
$window->_create;
|
||||||
|
|
||||||
|
set_wm_class($window->id, 'borderless', 'borderless');
|
||||||
|
$window->name('usethis');
|
||||||
|
$window->map;
|
||||||
|
sleep 0.25;
|
||||||
|
|
||||||
|
@content = @{get_ws_content($tmp)};
|
||||||
|
cmp_ok(@content, '==', 1, 'one node on this workspace now');
|
||||||
|
is($content[0]->{border}, 'none', 'no border');
|
||||||
|
|
||||||
|
$window->unmap;
|
||||||
|
sleep 0.25;
|
||||||
|
|
||||||
|
@content = @{get_ws_content($tmp)};
|
||||||
|
cmp_ok(@content, '==', 0, 'no nodes on this workspace now');
|
||||||
|
|
||||||
|
set_wm_class($window->id, 'borderless', 'borderless');
|
||||||
|
$window->name('notthis');
|
||||||
|
$window->map;
|
||||||
|
sleep 0.25;
|
||||||
|
|
||||||
|
@content = @{get_ws_content($tmp)};
|
||||||
|
cmp_ok(@content, '==', 1, 'one node on this workspace now');
|
||||||
|
is($content[0]->{border}, 'normal', 'no border');
|
||||||
|
|
||||||
|
|
||||||
|
exit_gracefully($process->pid);
|
||||||
|
|
||||||
done_testing;
|
done_testing;
|
||||||
|
|
Loading…
Reference in New Issue