aboutsummaryrefslogtreecommitdiff
path: root/sway/tree/container.c
diff options
context:
space:
mode:
authorBrian Ashworth <bosrsf04@gmail.com>2019-02-08 22:29:35 -0500
committeremersion <contact@emersion.fr>2019-02-09 09:24:43 +0100
commit995b6edab6fab33668a9bd320631b6ab65dc10c6 (patch)
treea7b42df4d2130842803718811f31f468fe1090c1 /sway/tree/container.c
parentf5190d1f797f5a9d0596ab6d31240a0e179ac457 (diff)
container_at_stacked: skip titles when zero pixels
It is possible to make the title bars have a zero pixel height while stacked, by using a blank font and no padding. This causes a division by zero when attempting to calculate the child index in container_at_stacked, which then results in a segfault when attempting to access the child at that bad index (INT_MIN). This just skips the check to see if the cursor is over a title bar of a child of a stacked container when the title bar height is zero since there will be no title bars.
Diffstat (limited to 'sway/tree/container.c')
-rw-r--r--sway/tree/container.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/sway/tree/container.c b/sway/tree/container.c
index 0ebdc51d..9358dad7 100644
--- a/sway/tree/container.c
+++ b/sway/tree/container.c
@@ -251,10 +251,12 @@ static struct sway_container *container_at_stacked(struct sway_node *parent,
// Title bars
int title_height = container_titlebar_height();
- int child_index = (ly - box.y) / title_height;
- if (child_index < children->length) {
- struct sway_container *child = children->items[child_index];
- return child;
+ if (title_height > 0) {
+ int child_index = (ly - box.y) / title_height;
+ if (child_index < children->length) {
+ struct sway_container *child = children->items[child_index];
+ return child;
+ }
}
// Surfaces