bugfix: set focus to workspace of an output
In `move_focus()`, when given an output, set the focus to the workspace of that
output instead of the output itself.
This fixes a bug that did not allow users to switch between outputs introduced
in afc6ad6
.
It also fixes other issues before that commit when a workspace with children
was selected and the user tried to switch focus in the direction of another
output.
This commit is contained in:
parent
70e73d71db
commit
8a03f138bf
1 changed files with 3 additions and 1 deletions
|
@ -67,9 +67,11 @@ bool move_focus(enum movement_direction direction) {
|
||||||
swayc_t *new_view = get_swayc_in_direction(old_view, direction);
|
swayc_t *new_view = get_swayc_in_direction(old_view, direction);
|
||||||
if (!new_view) {
|
if (!new_view) {
|
||||||
return false;
|
return false;
|
||||||
} else if (new_view->type == C_ROOT || new_view->type == C_OUTPUT) {
|
} else if (new_view->type == C_ROOT) {
|
||||||
sway_log(L_DEBUG, "Not setting focus above the workspace level");
|
sway_log(L_DEBUG, "Not setting focus above the workspace level");
|
||||||
return false;
|
return false;
|
||||||
|
} else if (new_view->type == C_OUTPUT) {
|
||||||
|
return set_focused_container(swayc_active_workspace_for(new_view));
|
||||||
} else if (direction == MOVE_PARENT) {
|
} else if (direction == MOVE_PARENT) {
|
||||||
return set_focused_container(new_view);
|
return set_focused_container(new_view);
|
||||||
} else if (config->mouse_warping) {
|
} else if (config->mouse_warping) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue