bugfix: move_to_screen really move to the right place

don't assume that -= + is the same as = - +
This commit is contained in:
Julien Danjou 2007-10-25 16:56:01 +02:00
parent 530a6ef104
commit 44f63f0ff8
1 changed files with 3 additions and 2 deletions

View File

@ -171,8 +171,8 @@ move_client_to_screen(Client *c, awesome_config *acf_new, Bool doresize)
si_old = get_screen_info(c->display, old_screen, NULL); si_old = get_screen_info(c->display, old_screen, NULL);
/* compute new coords in new screen */ /* compute new coords in new screen */
c->rx -= si_old[old_screen].x_org + si[c->screen].x_org; c->rx = (c->rx - si_old[old_screen].x_org) + si[c->screen].x_org;
c->ry -= si_old[old_screen].y_org + si[c->screen].y_org; c->ry = (c->ry - si_old[old_screen].y_org) + si[c->screen].y_org;
/* check that new coords are still in the screen */ /* check that new coords are still in the screen */
if(c->rw > si[c->screen].width) if(c->rw > si[c->screen].width)
c->rw = si[c->screen].width; c->rw = si[c->screen].width;
@ -188,6 +188,7 @@ move_client_to_screen(Client *c, awesome_config *acf_new, Bool doresize)
p_delete(&si); p_delete(&si);
p_delete(&si_old); p_delete(&si_old);
} }
/* redraw statusbar on all screens */ /* redraw statusbar on all screens */
drawstatusbar(&acf_new[old_screen - acf_new->screen]); drawstatusbar(&acf_new[old_screen - acf_new->screen]);
drawstatusbar(acf_new); drawstatusbar(acf_new);