summaryrefslogtreecommitdiff
path: root/openbox
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2007-05-01 12:17:37 +0000
committerDana Jansens <danakj@orodu.net>2007-05-01 12:17:37 +0000
commit564b727966ef1a38309d45b2ab040c3deeb658a4 (patch)
treee7c1c4396ba399da0ad54f245bfe48d96beae42c /openbox
parentcad10d8b6db8cb2be9802cea8e0c4db210431d50 (diff)
fix drawcontent=no resizing
Diffstat (limited to 'openbox')
-rw-r--r--openbox/client.c11
-rw-r--r--openbox/frame.c15
-rw-r--r--openbox/frame.h1
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);