all repos — openbox @ 2391410e3fd7767e266c0efe84fd34244ea29dc6

openbox fork - make it a bit more like ryudo

Fix negative ResizeRelative values with terminal windows (Fix bug 5228)

Inspired by patches from Brian Mock <mock.brian@gmail.com>.
Dana Jansens danakj@orodu.net
commit

2391410e3fd7767e266c0efe84fd34244ea29dc6

parent

62fd771d2f260992d35fb0c24d1e1009ff1cdc0d

1 files changed, 13 insertions(+), 4 deletions(-)

jump to
M openbox/actions/resizerelative.copenbox/actions/resizerelative.c

@@ -78,17 +78,26 @@ top = top * c->area.height / o->top_denom;

if (o->bottom_denom) bottom = bottom * c->area.height / o->bottom_denom; + if (left && ABS(left) < c->size_inc.width) + left = left < 0 ? -c->size_inc.width : c->size_inc.width; + if (right && ABS(right) < c->size_inc.width) + right = right < 0 ? -c->size_inc.width : c->size_inc.width; + if (top && ABS(top) < c->size_inc.height) + top = top < 0 ? -c->size_inc.height : c->size_inc.height; + if (bottom && ABS(bottom) < c->size_inc.height) + bottom = bottom < 0 ? -c->size_inc.height : c->size_inc.height; + // When resizing, if the resize has a non-zero value then make sure it // is at least as big as the size increment so the window does actually // resize. x = c->area.x; y = c->area.y; ow = c->area.width; - xoff = -MAX(left, (left ? c->size_inc.width : 0)); - nw = ow + MAX(right + left, (right + left ? c->size_inc.width : 0)); + xoff = -left; + nw = ow + right + left; oh = c->area.height; - yoff = -MAX(top, (top ? c->size_inc.height : 0)); - nh = oh + MAX(bottom + top, (bottom + top ? c->size_inc.height : 0)); + yoff = -top; + nh = oh + bottom + top; client_try_configure(c, &x, &y, &nw, &nh, &lw, &lh, TRUE); xoff = xoff == 0 ? 0 :