Added new criteria 'tiling' / 'floating'. (#2481)

These criteria allow selecting only windows in a specific mode, i.e.,
tiling and floating, respectively.

fixes #2406
This commit is contained in:
Ingo Bürk 2016-09-28 04:04:00 +02:00 committed by Michael Stapelberg
parent 0e73a6e9e7
commit 6a8fb69eff
6 changed files with 68 additions and 4 deletions

View File

@ -1679,6 +1679,9 @@ bindsym $mod+x [class="Firefox" window_role="About"] kill
# enable floating mode and move container to workspace 4 # enable floating mode and move container to workspace 4
for_window [class="^evil-app$"] floating enable, move container to workspace 4 for_window [class="^evil-app$"] floating enable, move container to workspace 4
# move all floating windows to the scratchpad
bindsym $mod+x [floating] move scratchpad
------------------------------------ ------------------------------------
The criteria which are currently implemented are: The criteria which are currently implemented are:
@ -1721,6 +1724,10 @@ con_id::
Compares the i3-internal container ID, which you can get via the IPC Compares the i3-internal container ID, which you can get via the IPC
interface. Handy for scripting. Use the special value +\_\_focused__+ interface. Handy for scripting. Use the special value +\_\_focused__+
to match only the currently focused window. to match only the currently focused window.
floating::
Only matches floating windows. This criterion requires no value.
tiling::
Only matches tiling windows. This criterion requires no value.
The criteria +class+, +instance+, +role+, +title+, +workspace+ and +mark+ are The criteria +class+, +instance+, +role+, +title+, +workspace+ and +mark+ are
actually regular expressions (PCRE). See +pcresyntax(3)+ or +perldoc perlre+ for actually regular expressions (PCRE). See +pcresyntax(3)+ or +perldoc perlre+ for

View File

@ -474,9 +474,9 @@ struct Match {
M_DOCK_BOTTOM = 3 M_DOCK_BOTTOM = 3
} dock; } dock;
xcb_window_t id; xcb_window_t id;
enum { M_ANY = 0, enum { WM_ANY = 0,
M_TILING, WM_TILING,
M_FLOATING } floating; WM_FLOATING } window_mode;
Con *con_id; Con *con_id;
/* Where the window looking for a match should be inserted: /* Where the window looking for a match should be inserted:

View File

@ -53,6 +53,8 @@ state CRITERIA:
ctype = 'title' -> CRITERION ctype = 'title' -> CRITERION
ctype = 'urgent' -> CRITERION ctype = 'urgent' -> CRITERION
ctype = 'workspace' -> CRITERION ctype = 'workspace' -> CRITERION
ctype = 'tiling', 'floating'
-> call cmd_criteria_add($ctype, NULL); CRITERIA
']' -> call cmd_criteria_match_windows(); INITIAL ']' -> call cmd_criteria_match_windows(); INITIAL
state CRITERION: state CRITERION:

View File

@ -173,6 +173,8 @@ state CRITERIA:
ctype = 'title' -> CRITERION ctype = 'title' -> CRITERION
ctype = 'urgent' -> CRITERION ctype = 'urgent' -> CRITERION
ctype = 'workspace' -> CRITERION ctype = 'workspace' -> CRITERION
ctype = 'tiling', 'floating'
-> call cfg_criteria_add($ctype, NULL); CRITERIA
']' ']'
-> call cfg_criteria_pop_state() -> call cfg_criteria_pop_state()

View File

@ -28,6 +28,7 @@
void match_init(Match *match) { void match_init(Match *match) {
memset(match, 0, sizeof(Match)); memset(match, 0, sizeof(Match));
match->urgent = U_DONTCHECK; match->urgent = U_DONTCHECK;
match->window_mode = WM_ANY;
/* we use this as the placeholder value for "not set". */ /* we use this as the placeholder value for "not set". */
match->window_type = UINT32_MAX; match->window_type = UINT32_MAX;
} }
@ -53,7 +54,7 @@ bool match_is_empty(Match *match) {
match->window_type == UINT32_MAX && match->window_type == UINT32_MAX &&
match->con_id == NULL && match->con_id == NULL &&
match->dock == M_NODOCK && match->dock == M_NODOCK &&
match->floating == M_ANY); match->window_mode == WM_ANY);
} }
/* /*
@ -243,6 +244,21 @@ bool match_matches_window(Match *match, i3Window *window) {
} }
} }
if (match->window_mode != WM_ANY) {
if ((con = con_by_window_id(window->id)) == NULL)
return false;
const bool floating = (con_inside_floating(con) != NULL);
if ((match->window_mode == WM_TILING && floating) ||
(match->window_mode == WM_FLOATING && !floating)) {
LOG("window_mode does not match\n");
return false;
}
LOG("window_mode matches\n");
}
return true; return true;
} }
@ -384,5 +400,15 @@ void match_parse_property(Match *match, const char *ctype, const char *cvalue) {
return; return;
} }
if (strcmp(ctype, "tiling") == 0) {
match->window_mode = WM_TILING;
return;
}
if (strcmp(ctype, "floating") == 0) {
match->window_mode = WM_FLOATING;
return;
}
ELOG("Unknown criterion: %s\n", ctype); ELOG("Unknown criterion: %s\n", ctype);
} }

View File

@ -459,6 +459,33 @@ is_deeply($nodes[0]->{nodes}[0]->{marks}, [ 'triggered' ], "mark set for workspa
exit_gracefully($pid); exit_gracefully($pid);
##############################################################
# 13: check that the tiling / floating criteria work.
##############################################################
$config = <<"EOT";
# i3 config file (v4)
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
for_window [tiling] mark tiled
for_window [floating] mark floated
EOT
$pid = launch_with_config($config);
$tmp = fresh_workspace;
open_window;
open_floating_window;
@nodes = @{get_ws($tmp)->{nodes}};
cmp_ok(@nodes, '==', 1, 'one tiling container on this workspace');
is_deeply($nodes[0]->{marks}, [ 'tiled' ], "mark set for 'tiling' criterion");
@nodes = @{get_ws($tmp)->{floating_nodes}};
cmp_ok(@nodes, '==', 1, 'one floating container on this workspace');
is_deeply($nodes[0]->{nodes}[0]->{marks}, [ 'floated' ], "mark set for 'floating' criterion");
exit_gracefully($pid);
############################################################## ##############################################################
done_testing; done_testing;