mirror of
https://github.com/swaywm/sway.git
synced 2024-12-30 17:06:40 +01:00
Altered resize command to prevent resizing past min h/w
This commit is contained in:
parent
e067913fb8
commit
ad1ca31dd5
2 changed files with 117 additions and 32 deletions
147
sway/commands.c
147
sway/commands.c
|
@ -497,43 +497,85 @@ static bool cmd_resize(struct sway_config *config, int argc, char **argv) {
|
||||||
}
|
}
|
||||||
sway_log(L_DEBUG, "Found the proper parent: %p. It has %d l conts, and %d r conts", parent->parent, lnumber, rnumber);
|
sway_log(L_DEBUG, "Found the proper parent: %p. It has %d l conts, and %d r conts", parent->parent, lnumber, rnumber);
|
||||||
//TODO: Ensure rounding is done in such a way that there are NO pixel leaks
|
//TODO: Ensure rounding is done in such a way that there are NO pixel leaks
|
||||||
|
bool valid = true;
|
||||||
for (i = 0; i < parent->parent->children->length; i++) {
|
for (i = 0; i < parent->parent->children->length; i++) {
|
||||||
bool valid = true;
|
|
||||||
sibling = parent->parent->children->items[i];
|
sibling = parent->parent->children->items[i];
|
||||||
if (sibling->x != focused->x) {
|
if (sibling->x != focused->x) {
|
||||||
if (sibling->x < parent->x) {
|
if (sibling->x < parent->x) {
|
||||||
double pixels = -1 * amount;
|
double pixels = -1 * amount;
|
||||||
pixels /= lnumber;
|
pixels /= lnumber;
|
||||||
if (rnumber) {
|
if (rnumber) {
|
||||||
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_RIGHT);
|
if ((sibling->width + pixels/2) < min_sane_w) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_RIGHT);
|
if ((sibling->width + pixels) < min_sane_w) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (sibling->x > parent->x) {
|
} else if (sibling->x > parent->x) {
|
||||||
double pixels = -1 * amount;
|
double pixels = -1 * amount;
|
||||||
pixels /= rnumber;
|
pixels /= rnumber;
|
||||||
if (lnumber) {
|
if (lnumber) {
|
||||||
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_LEFT);
|
if ((sibling->width + pixels/2) < min_sane_w) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_LEFT);
|
if ((sibling->width + pixels) < min_sane_w) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (rnumber != 0 && lnumber != 0) {
|
double pixels = amount;
|
||||||
double pixels = amount;
|
if (parent->width + pixels < min_sane_w) {
|
||||||
pixels /= 2;
|
valid = false;
|
||||||
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_LEFT);
|
break;
|
||||||
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_RIGHT);
|
|
||||||
} else if (rnumber) {
|
|
||||||
recursive_resize(parent, amount, WLC_RESIZE_EDGE_RIGHT);
|
|
||||||
} else if (lnumber) {
|
|
||||||
recursive_resize(parent, amount, WLC_RESIZE_EDGE_LEFT);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Recursive resize does not handle positions, let arrange_windows
|
if (valid) {
|
||||||
// take care of that.
|
for (i = 0; i < parent->parent->children->length; i++) {
|
||||||
arrange_windows(swayc_active_workspace(), -1, -1);
|
sibling = parent->parent->children->items[i];
|
||||||
|
if (sibling->x != focused->x) {
|
||||||
|
if (sibling->x < parent->x) {
|
||||||
|
double pixels = -1 * amount;
|
||||||
|
pixels /= lnumber;
|
||||||
|
if (rnumber) {
|
||||||
|
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_RIGHT);
|
||||||
|
} else {
|
||||||
|
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_RIGHT);
|
||||||
|
}
|
||||||
|
} else if (sibling->x > parent->x) {
|
||||||
|
double pixels = -1 * amount;
|
||||||
|
pixels /= rnumber;
|
||||||
|
if (lnumber) {
|
||||||
|
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_LEFT);
|
||||||
|
} else {
|
||||||
|
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_LEFT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (rnumber != 0 && lnumber != 0) {
|
||||||
|
double pixels = amount;
|
||||||
|
pixels /= 2;
|
||||||
|
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_LEFT);
|
||||||
|
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_RIGHT);
|
||||||
|
} else if (rnumber) {
|
||||||
|
recursive_resize(parent, amount, WLC_RESIZE_EDGE_RIGHT);
|
||||||
|
} else if (lnumber) {
|
||||||
|
recursive_resize(parent, amount, WLC_RESIZE_EDGE_LEFT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Recursive resize does not handle positions, let arrange_windows
|
||||||
|
// take care of that.
|
||||||
|
arrange_windows(swayc_active_workspace(), -1, -1);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
} else if (strcmp(argv[1], "height") == 0) {
|
} else if (strcmp(argv[1], "height") == 0) {
|
||||||
int tnumber = 0;
|
int tnumber = 0;
|
||||||
|
@ -561,6 +603,7 @@ static bool cmd_resize(struct sway_config *config, int argc, char **argv) {
|
||||||
}
|
}
|
||||||
sway_log(L_DEBUG, "Found the proper parent: %p. It has %d b conts, and %d t conts", parent->parent, bnumber, tnumber);
|
sway_log(L_DEBUG, "Found the proper parent: %p. It has %d b conts, and %d t conts", parent->parent, bnumber, tnumber);
|
||||||
//TODO: Ensure rounding is done in such a way that there are NO pixel leaks
|
//TODO: Ensure rounding is done in such a way that there are NO pixel leaks
|
||||||
|
bool valid = true;
|
||||||
for (i = 0; i < parent->parent->children->length; i++) {
|
for (i = 0; i < parent->parent->children->length; i++) {
|
||||||
sibling = parent->parent->children->items[i];
|
sibling = parent->parent->children->items[i];
|
||||||
if (sibling->y != focused->y) {
|
if (sibling->y != focused->y) {
|
||||||
|
@ -568,32 +611,74 @@ static bool cmd_resize(struct sway_config *config, int argc, char **argv) {
|
||||||
double pixels = -1 * amount;
|
double pixels = -1 * amount;
|
||||||
pixels /= bnumber;
|
pixels /= bnumber;
|
||||||
if (tnumber) {
|
if (tnumber) {
|
||||||
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_BOTTOM);
|
if ((sibling->height + pixels/2) < min_sane_h) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_BOTTOM);
|
if ((sibling->height + pixels) < min_sane_h) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else if (sibling->x > parent->x) {
|
} else if (sibling->y > parent->y) {
|
||||||
double pixels = -1 * amount;
|
double pixels = -1 * amount;
|
||||||
pixels /= tnumber;
|
pixels /= tnumber;
|
||||||
if (bnumber) {
|
if (bnumber) {
|
||||||
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_TOP);
|
if ((sibling->height + pixels/2) < min_sane_h) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_TOP);
|
if ((sibling->height + pixels) < min_sane_h) {
|
||||||
|
valid = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (bnumber != 0 && tnumber != 0) {
|
double pixels = amount;
|
||||||
double pixels = amount/2;
|
if (parent->height + pixels < min_sane_h) {
|
||||||
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_TOP);
|
valid = false;
|
||||||
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_BOTTOM);
|
break;
|
||||||
} else if (tnumber) {
|
|
||||||
recursive_resize(parent, amount, WLC_RESIZE_EDGE_TOP);
|
|
||||||
} else if (bnumber) {
|
|
||||||
recursive_resize(parent, amount, WLC_RESIZE_EDGE_BOTTOM);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
arrange_windows(swayc_active_workspace(), -1, -1);
|
if (valid) {
|
||||||
|
for (i = 0; i < parent->parent->children->length; i++) {
|
||||||
|
sibling = parent->parent->children->items[i];
|
||||||
|
if (sibling->y != focused->y) {
|
||||||
|
if (sibling->y < parent->y) {
|
||||||
|
double pixels = -1 * amount;
|
||||||
|
pixels /= bnumber;
|
||||||
|
if (tnumber) {
|
||||||
|
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_BOTTOM);
|
||||||
|
} else {
|
||||||
|
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_BOTTOM);
|
||||||
|
}
|
||||||
|
} else if (sibling->x > parent->x) {
|
||||||
|
double pixels = -1 * amount;
|
||||||
|
pixels /= tnumber;
|
||||||
|
if (bnumber) {
|
||||||
|
recursive_resize(sibling, pixels/2, WLC_RESIZE_EDGE_TOP);
|
||||||
|
} else {
|
||||||
|
recursive_resize(sibling, pixels, WLC_RESIZE_EDGE_TOP);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (bnumber != 0 && tnumber != 0) {
|
||||||
|
double pixels = amount/2;
|
||||||
|
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_TOP);
|
||||||
|
recursive_resize(parent, pixels, WLC_RESIZE_EDGE_BOTTOM);
|
||||||
|
} else if (tnumber) {
|
||||||
|
recursive_resize(parent, amount, WLC_RESIZE_EDGE_TOP);
|
||||||
|
} else if (bnumber) {
|
||||||
|
recursive_resize(parent, amount, WLC_RESIZE_EDGE_BOTTOM);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
arrange_windows(swayc_active_workspace(), -1, -1);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -435,7 +435,7 @@ static bool handle_pointer_motion(wlc_handle handle, uint32_t time, const struct
|
||||||
} else if (get_swayc_in_direction(pointer_state.tiling.init_view, MOVE_UP) == view) {
|
} else if (get_swayc_in_direction(pointer_state.tiling.init_view, MOVE_UP) == view) {
|
||||||
pointer_state.tiling.lock_pos.y = pointer_state.tiling.init_view->y + 20;
|
pointer_state.tiling.lock_pos.y = pointer_state.tiling.init_view->y + 20;
|
||||||
pointer_state.lock.temp_up = true;
|
pointer_state.lock.temp_up = true;
|
||||||
} else if (get_swayc_in_direction(pointer_state.tiling.init_view, MOVE_UP) == view) {
|
} else if (get_swayc_in_direction(pointer_state.tiling.init_view, MOVE_DOWN) == view) {
|
||||||
pointer_state.tiling.lock_pos.y = pointer_state.tiling.init_view->y + pointer_state.tiling.init_view->height - 20;
|
pointer_state.tiling.lock_pos.y = pointer_state.tiling.init_view->y + pointer_state.tiling.init_view->height - 20;
|
||||||
pointer_state.lock.temp_down = true;
|
pointer_state.lock.temp_down = true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue