X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fplace.c;h=6a210b0f6377e60770c34fa36e206d284d762c84;hb=b41c3395313a97741f2f76b9133dc3b0b8eb5bbc;hp=b6ede657f3c4711937a26b5d583be280c5889d75;hpb=1514ce75b654903003c7f38fec6482d61c79bb48;p=chaz%2Fopenbox diff --git a/openbox/place.c b/openbox/place.c index b6ede657..6a210b0f 100644 --- a/openbox/place.c +++ b/openbox/place.c @@ -53,7 +53,7 @@ static Rect *pick_pointer_head(ObClient *c) gboolean contain = RECT_CONTAINS(*monitor, px, py); g_free(monitor); if (contain) - return screen_area_monitor(c->desktop, i, NULL); + return screen_area(c->desktop, i, NULL); } g_assert_not_reached(); } @@ -131,7 +131,7 @@ static Rect **pick_head(ObClient *c) add_choice(choice, i); for (i = 0; i < screen_num_monitors; ++i) - area[i] = screen_area_monitor(c->desktop, choice[i], NULL); + area[i] = screen_area(c->desktop, choice[i], NULL); return area; } @@ -326,8 +326,12 @@ static gboolean place_nooverlap(ObClient *c, gint *x, gint *y) Rect *r = maxit->data; /* center it in the area */ - *x = r->x + (r->width - c->frame->area.width) / 2; - *y = r->y + (r->height - c->frame->area.height) / 2; + *x = r->x; + *y = r->y; + if (config_place_center) { + *x += (r->width - c->frame->area.width) / 2; + *y += (r->height - c->frame->area.height) / 2; + } ret = TRUE; } @@ -380,8 +384,8 @@ static gboolean place_per_app_setting(ObClient *client, gint *x, gint *y, screen = pick_pointer_head(client); else if (settings->monitor > 0 && (guint)settings->monitor <= screen_num_monitors) - screen = screen_area_monitor(client->desktop, - (guint)settings->monitor - 1, NULL); + screen = screen_area(client->desktop, (guint)settings->monitor - 1, + NULL); else { Rect **areas; guint i; @@ -478,12 +482,10 @@ gboolean place_client(ObClient *client, gint *x, gint *y, (config_place_policy == OB_PLACE_POLICY_MOUSE && place_under_mouse(client, x, y)) || place_nooverlap(client, x, y) || - place_under_mouse(client, x, y) || place_random(client, x, y); g_assert(ret); /* get where the client should be */ - frame_frame_gravity(client->frame, x, y, - client->area.width, client->area.height); + frame_frame_gravity(client->frame, x, y); return ret; }