mirror of
https://github.com/swaywm/sway.git
synced 2024-12-28 16:06:37 +01:00
Workspace move cycle
On move workspace to direction: Try the farthest on the opposite direction if no workspace is found at given direction.
This commit is contained in:
parent
b945957b9b
commit
1a72149d88
1 changed files with 38 additions and 10 deletions
|
@ -26,7 +26,20 @@ static const char *expected_syntax =
|
||||||
"'move <container|window|workspace> [to] output <name|direction>' or "
|
"'move <container|window|workspace> [to] output <name|direction>' or "
|
||||||
"'move <container|window> [to] mark <mark>'";
|
"'move <container|window> [to] mark <mark>'";
|
||||||
|
|
||||||
static struct sway_container *output_in_direction(const char *direction,
|
enum wlr_direction opposite_direction(enum wlr_direction d) {
|
||||||
|
switch (d) {
|
||||||
|
case WLR_DIRECTION_UP:
|
||||||
|
return WLR_DIRECTION_DOWN;
|
||||||
|
case WLR_DIRECTION_DOWN:
|
||||||
|
return WLR_DIRECTION_UP;
|
||||||
|
case WLR_DIRECTION_RIGHT:
|
||||||
|
return WLR_DIRECTION_LEFT;
|
||||||
|
default:
|
||||||
|
return WLR_DIRECTION_RIGHT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct sway_container *output_in_direction(const char *direction_string,
|
||||||
struct wlr_output *reference, int ref_lx, int ref_ly) {
|
struct wlr_output *reference, int ref_lx, int ref_ly) {
|
||||||
struct {
|
struct {
|
||||||
char *name;
|
char *name;
|
||||||
|
@ -37,19 +50,34 @@ static struct sway_container *output_in_direction(const char *direction,
|
||||||
{ "left", WLR_DIRECTION_LEFT },
|
{ "left", WLR_DIRECTION_LEFT },
|
||||||
{ "right", WLR_DIRECTION_RIGHT },
|
{ "right", WLR_DIRECTION_RIGHT },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum wlr_direction direction;
|
||||||
|
|
||||||
for (size_t i = 0; i < sizeof(names) / sizeof(names[0]); ++i) {
|
for (size_t i = 0; i < sizeof(names) / sizeof(names[0]); ++i) {
|
||||||
if (strcasecmp(names[i].name, direction) == 0) {
|
if (strcasecmp(names[i].name, direction_string) == 0) {
|
||||||
struct wlr_output *adjacent = wlr_output_layout_adjacent_output(
|
direction = names[i].direction;
|
||||||
root_container.sway_root->output_layout,
|
|
||||||
names[i].direction, reference, ref_lx, ref_ly);
|
|
||||||
if (adjacent) {
|
|
||||||
struct sway_output *sway_output = adjacent->data;
|
|
||||||
return sway_output->swayc;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return output_by_name(direction);
|
|
||||||
|
if (direction) {
|
||||||
|
struct wlr_output *target = wlr_output_layout_adjacent_output(
|
||||||
|
root_container.sway_root->output_layout,
|
||||||
|
direction, reference, ref_lx, ref_ly);
|
||||||
|
|
||||||
|
if (!target) {
|
||||||
|
target = wlr_output_layout_farthest_output(
|
||||||
|
root_container.sway_root->output_layout,
|
||||||
|
opposite_direction(direction), reference, ref_lx, ref_ly);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (target) {
|
||||||
|
struct sway_output *sway_output = target->data;
|
||||||
|
return sway_output->swayc;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return output_by_name(direction_string);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void container_move_to(struct sway_container *container,
|
static void container_move_to(struct sway_container *container,
|
||||||
|
|
Loading…
Reference in a new issue