move windows when the number of desktops changes and they arent on a desktop anymore
This commit is contained in:
parent
b2c508d97e
commit
d1de946a62
1 changed files with 11 additions and 20 deletions
|
@ -153,7 +153,9 @@ void screen_startup()
|
||||||
/* get the initial size */
|
/* get the initial size */
|
||||||
screen_resize();
|
screen_resize();
|
||||||
|
|
||||||
|
screen_num_desktops = 0;
|
||||||
screen_set_num_desktops(4);
|
screen_set_num_desktops(4);
|
||||||
|
screen_desktop = 0;
|
||||||
screen_set_desktop(0);
|
screen_set_desktop(0);
|
||||||
|
|
||||||
/* don't start in showing-desktop mode */
|
/* don't start in showing-desktop mode */
|
||||||
|
@ -206,28 +208,10 @@ void screen_set_num_desktops(guint num)
|
||||||
{
|
{
|
||||||
guint i, old;
|
guint i, old;
|
||||||
gulong *viewport;
|
gulong *viewport;
|
||||||
|
GSList *it;
|
||||||
|
|
||||||
g_assert(num > 0);
|
g_assert(num > 0);
|
||||||
|
|
||||||
/* move windows on desktops that will no longer exist! */
|
|
||||||
/* XXX
|
|
||||||
std::list<Client*>::iterator it, end = clients.end();
|
|
||||||
for (it = clients.begin(); it != end; ++it) {
|
|
||||||
unsigned int d = (*it)->desktop();
|
|
||||||
if (d >= num && d != 0xffffffff) {
|
|
||||||
XEvent ce;
|
|
||||||
ce.xclient.type = ClientMessage;
|
|
||||||
ce.xclient.message_type = otk::Property::atoms.net_wm_desktop;
|
|
||||||
ce.xclient.display = **otk::display;
|
|
||||||
ce.xclient.window = (*it)->window();
|
|
||||||
ce.xclient.format = 32;
|
|
||||||
ce.xclient.data.l[0] = num - 1;
|
|
||||||
XSendEvent(**otk::display, _info->rootWindow(), false,
|
|
||||||
SubstructureNotifyMask | SubstructureRedirectMask, &ce);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
old = screen_num_desktops;
|
old = screen_num_desktops;
|
||||||
screen_num_desktops = num;
|
screen_num_desktops = num;
|
||||||
PROP_SET32(ob_root, net_number_of_desktops, cardinal, num);
|
PROP_SET32(ob_root, net_number_of_desktops, cardinal, num);
|
||||||
|
@ -256,6 +240,13 @@ void screen_set_num_desktops(guint num)
|
||||||
for (i = old; i < num; ++i)
|
for (i = old; i < num; ++i)
|
||||||
focus_order[i] = NULL;
|
focus_order[i] = NULL;
|
||||||
|
|
||||||
|
/* move windows on desktops that will no longer exist! */
|
||||||
|
for (it = client_list; it != NULL; it = it->next) {
|
||||||
|
Client *c = it->data;
|
||||||
|
if (c->desktop >= num)
|
||||||
|
client_set_desktop(num - 1);
|
||||||
|
}
|
||||||
|
|
||||||
dispatch_ob(Event_Ob_NumDesktops, num, old);
|
dispatch_ob(Event_Ob_NumDesktops, num, old);
|
||||||
|
|
||||||
/* change our desktop if we're on one that no longer exists! */
|
/* change our desktop if we're on one that no longer exists! */
|
||||||
|
|
Loading…
Reference in a new issue