From 564b727966ef1a38309d45b2ab040c3deeb658a4 Mon Sep 17 00:00:00 2001 From: Dana Jansens Date: Tue, 1 May 2007 12:17:37 +0000 Subject: [PATCH] fix drawcontent=no resizing --- openbox/client.c | 11 +++++++++-- openbox/frame.c | 15 ++++++++++----- openbox/frame.h | 1 + 3 files changed, 20 insertions(+), 7 deletions(-) diff --git a/openbox/client.c b/openbox/client.c index 4abff4c5..33967962 100644 --- a/openbox/client.c +++ b/openbox/client.c @@ -2437,8 +2437,11 @@ void client_configure_full(ObClient *self, gint x, gint y, gint w, gint h, (resized && config_resize_redraw)))); /* if the client is enlarging, then resize the client before the frame */ - if (send_resize_client && user && (w > oldw || h > oldh)) + if (send_resize_client && user && (w > oldw || h > oldh)) { XResizeWindow(ob_display, self->window, MAX(w, oldw), MAX(h, oldh)); + /* resize the plate to show the client padding color underneath */ + frame_adjust_client_area(self->frame); + } /* find the frame's dimensions and move/resize it */ if (self->decorations != fdecor || self->max_horz != fhorz) @@ -2484,8 +2487,12 @@ void client_configure_full(ObClient *self, gint x, gint y, gint w, gint h, } /* if the client is shrinking, then resize the frame before the client */ - if (send_resize_client && (!user || (w <= oldw || h <= oldh))) + if (send_resize_client && (!user || (w <= oldw || h <= oldh))) { + /* resize the plate to show the client padding color underneath */ + frame_adjust_client_area(self->frame); + XResizeWindow(ob_display, self->window, w, h); + } XFlush(ob_display); } diff --git a/openbox/frame.c b/openbox/frame.c index f12dbfb2..8feef931 100644 --- a/openbox/frame.c +++ b/openbox/frame.c @@ -442,11 +442,9 @@ void frame_adjust_area(ObFrame *self, gboolean moved, self->client->area.height + self->cbwidth_y * 2); - /* move and resize the plate */ - XMoveResizeWindow(ob_display, self->plate, - self->cbwidth_x, self->cbwidth_y, - self->client->area.width, - self->client->area.height); + /* move the plate */ + XMoveWindow(ob_display, self->plate, + self->cbwidth_x, self->cbwidth_y); /* when the client has StaticGravity, it likes to move around. */ XMoveWindow(ob_display, self->client->window, 0, 0); @@ -511,6 +509,13 @@ void frame_adjust_area(ObFrame *self, gboolean moved, ob_rr_theme->label_height); } +void frame_adjust_client_area(ObFrame *self) +{ + /* resize the plate */ + XResizeWindow(ob_display, self->plate, + self->client->area.width, self->client->area.height); +} + void frame_adjust_state(ObFrame *self) { framerender_frame(self); diff --git a/openbox/frame.h b/openbox/frame.h index 344c1530..19bade78 100644 --- a/openbox/frame.h +++ b/openbox/frame.h @@ -151,6 +151,7 @@ void frame_adjust_theme(ObFrame *self); void frame_adjust_shape(ObFrame *self); void frame_adjust_area(ObFrame *self, gboolean moved, gboolean resized, gboolean fake); +void frame_adjust_client_area(ObFrame *self); void frame_adjust_state(ObFrame *self); void frame_adjust_focus(ObFrame *self, gboolean hilite); void frame_adjust_title(ObFrame *self); -- 2.39.2