all repos — openbox @ 5bebe5fbf8ab53f114ecc628d4150e1c508d788b

openbox fork - make it a bit more like ryudo

if the client is growing, resize it before the frame. if its shrinking, then resize the frame first. reduces flicker lots.
Dana Jansens danakj@orodu.net
commit

5bebe5fbf8ab53f114ecc628d4150e1c508d788b

parent

9f2a844beb62287e12e75bf207e4c55bc14b6209

1 files changed, 14 insertions(+), 2 deletions(-)

jump to
M openbox/client.copenbox/client.c

@@ -1756,6 +1756,8 @@ int x, int y, int w, int h,

gboolean user, gboolean final, gboolean force_reply) { + gint oldw, oldh; + gboolean send_resize_client; gboolean moved = FALSE, resized = FALSE; guint fdecor = self->frame->decorations; gboolean fhorz = self->frame->max_horz;

@@ -1917,13 +1919,19 @@

moved = x != self->area.x || y != self->area.y; resized = w != self->area.width || h != self->area.height; + oldw = self->area.width; + oldh = self->area.height; RECT_SET(self->area, x, y, w, h); /* for app-requested resizes, always resize if 'resized' is true. for user-requested ones, only resize if final is true, or when resizing in redraw mode */ - if ((!user && resized) || - (user && (final || (resized && config_redraw_resize)))) + send_resize_client = ((!user && resized) || + (user && (final || + (resized && config_redraw_resize)))); + + /* if the client is enlarging, the resize the client before the frame */ + if (send_resize_client && (w > oldw || h > oldh)) XResizeWindow(ob_display, self->window, w, h); /* move/resize the frame to match the request */

@@ -1956,6 +1964,10 @@ XSendEvent(event.xconfigure.display, event.xconfigure.window,

FALSE, StructureNotifyMask, &event); } } + + /* if the client is shrinking, then resize the frame before the client */ + if (send_resize_client && (w <= oldw && h <= oldh)) + XResizeWindow(ob_display, self->window, w, h); } void client_fullscreen(ObClient *self, gboolean fs, gboolean savearea)