move logic for add/remove desktop into screen.c
This commit is contained in:
parent
b1a50affe5
commit
8bcd349e4e
3 changed files with 75 additions and 62 deletions
|
@ -1,7 +1,5 @@
|
||||||
#include "openbox/actions.h"
|
#include "openbox/actions.h"
|
||||||
#include "openbox/screen.h"
|
#include "openbox/screen.h"
|
||||||
#include "openbox/client.h"
|
|
||||||
#include "openbox/debug.h"
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -78,66 +76,10 @@ static gboolean run_func(ObActionsData *data, gpointer options)
|
||||||
|
|
||||||
actions_client_move(data, FALSE);
|
actions_client_move(data, FALSE);
|
||||||
|
|
||||||
if (o->add) {
|
if (o->add)
|
||||||
screen_set_num_desktops(screen_num_desktops+1);
|
screen_add_desktop(o->current);
|
||||||
|
else
|
||||||
/* move all the clients over */
|
screen_remove_desktop(o->current);
|
||||||
if (o->current) {
|
|
||||||
GList *it;
|
|
||||||
|
|
||||||
for (it = client_list; it; it = g_list_next(it)) {
|
|
||||||
ObClient *c = it->data;
|
|
||||||
if (c->desktop != DESKTOP_ALL && c->desktop >= screen_desktop)
|
|
||||||
client_set_desktop(c, c->desktop+1, FALSE, TRUE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (screen_num_desktops > 1) {
|
|
||||||
guint rmdesktop, movedesktop;
|
|
||||||
GList *it, *stacking_copy;
|
|
||||||
|
|
||||||
/* what desktop are we removing and moving to? */
|
|
||||||
if (o->current)
|
|
||||||
rmdesktop = screen_desktop;
|
|
||||||
else
|
|
||||||
rmdesktop = screen_num_desktops - 1;
|
|
||||||
if (rmdesktop < screen_num_desktops - 1)
|
|
||||||
movedesktop = rmdesktop + 1;
|
|
||||||
else
|
|
||||||
movedesktop = rmdesktop;
|
|
||||||
|
|
||||||
/* make a copy of the list cuz we're changing it */
|
|
||||||
stacking_copy = g_list_copy(stacking_list);
|
|
||||||
for (it = g_list_last(stacking_copy); it; it = g_list_previous(it)) {
|
|
||||||
if (WINDOW_IS_CLIENT(it->data)) {
|
|
||||||
ObClient *c = it->data;
|
|
||||||
guint d = c->desktop;
|
|
||||||
if (d != DESKTOP_ALL && d >= movedesktop) {
|
|
||||||
client_set_desktop(c, c->desktop - 1, TRUE, TRUE);
|
|
||||||
ob_debug("moving window %s\n", c->title);
|
|
||||||
}
|
|
||||||
/* raise all the windows that are on the current desktop which
|
|
||||||
is being merged */
|
|
||||||
if ((screen_desktop == rmdesktop - 1 ||
|
|
||||||
screen_desktop == rmdesktop) &&
|
|
||||||
(d == DESKTOP_ALL || d == screen_desktop))
|
|
||||||
{
|
|
||||||
stacking_raise(CLIENT_AS_WINDOW(c));
|
|
||||||
ob_debug("raising window %s\n", c->title);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* act like we're changing desktops */
|
|
||||||
if (screen_desktop < screen_num_desktops - 1) {
|
|
||||||
gint d = screen_desktop;
|
|
||||||
screen_desktop = screen_last_desktop;
|
|
||||||
screen_set_desktop(d, TRUE);
|
|
||||||
ob_debug("fake desktop change\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
screen_set_num_desktops(screen_num_desktops-1);
|
|
||||||
}
|
|
||||||
|
|
||||||
actions_client_move(data, TRUE);
|
actions_client_move(data, TRUE);
|
||||||
|
|
||||||
|
|
|
@ -635,6 +635,72 @@ void screen_set_desktop(guint num, gboolean dofocus)
|
||||||
screen_desktop_user_time = event_curtime;
|
screen_desktop_user_time = event_curtime;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void screen_add_desktop(gboolean current)
|
||||||
|
{
|
||||||
|
screen_set_num_desktops(screen_num_desktops+1);
|
||||||
|
|
||||||
|
/* move all the clients over */
|
||||||
|
if (current) {
|
||||||
|
GList *it;
|
||||||
|
|
||||||
|
for (it = client_list; it; it = g_list_next(it)) {
|
||||||
|
ObClient *c = it->data;
|
||||||
|
if (c->desktop != DESKTOP_ALL && c->desktop >= screen_desktop)
|
||||||
|
client_set_desktop(c, c->desktop+1, FALSE, TRUE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void screen_remove_desktop(gboolean current)
|
||||||
|
{
|
||||||
|
guint rmdesktop, movedesktop;
|
||||||
|
GList *it, *stacking_copy;
|
||||||
|
|
||||||
|
if (screen_num_desktops <= 1) return;
|
||||||
|
|
||||||
|
/* what desktop are we removing and moving to? */
|
||||||
|
if (current)
|
||||||
|
rmdesktop = screen_desktop;
|
||||||
|
else
|
||||||
|
rmdesktop = screen_num_desktops - 1;
|
||||||
|
if (rmdesktop < screen_num_desktops - 1)
|
||||||
|
movedesktop = rmdesktop + 1;
|
||||||
|
else
|
||||||
|
movedesktop = rmdesktop;
|
||||||
|
|
||||||
|
/* make a copy of the list cuz we're changing it */
|
||||||
|
stacking_copy = g_list_copy(stacking_list);
|
||||||
|
for (it = g_list_last(stacking_copy); it; it = g_list_previous(it)) {
|
||||||
|
if (WINDOW_IS_CLIENT(it->data)) {
|
||||||
|
ObClient *c = it->data;
|
||||||
|
guint d = c->desktop;
|
||||||
|
if (d != DESKTOP_ALL && d >= movedesktop) {
|
||||||
|
client_set_desktop(c, c->desktop - 1, TRUE, TRUE);
|
||||||
|
ob_debug("moving window %s\n", c->title);
|
||||||
|
}
|
||||||
|
/* raise all the windows that are on the current desktop which
|
||||||
|
is being merged */
|
||||||
|
if ((screen_desktop == rmdesktop - 1 ||
|
||||||
|
screen_desktop == rmdesktop) &&
|
||||||
|
(d == DESKTOP_ALL || d == screen_desktop))
|
||||||
|
{
|
||||||
|
stacking_raise(CLIENT_AS_WINDOW(c));
|
||||||
|
ob_debug("raising window %s\n", c->title);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* act like we're changing desktops */
|
||||||
|
if (screen_desktop < screen_num_desktops - 1) {
|
||||||
|
gint d = screen_desktop;
|
||||||
|
screen_desktop = screen_last_desktop;
|
||||||
|
screen_set_desktop(d, TRUE);
|
||||||
|
ob_debug("fake desktop change\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
screen_set_num_desktops(screen_num_desktops-1);
|
||||||
|
}
|
||||||
|
|
||||||
static void get_row_col(guint d, guint *r, guint *c)
|
static void get_row_col(guint d, guint *r, guint *c)
|
||||||
{
|
{
|
||||||
switch (screen_desktop_layout.orientation) {
|
switch (screen_desktop_layout.orientation) {
|
||||||
|
|
|
@ -67,6 +67,11 @@ void screen_resize();
|
||||||
void screen_set_num_desktops(guint num);
|
void screen_set_num_desktops(guint num);
|
||||||
/*! Change the current desktop */
|
/*! Change the current desktop */
|
||||||
void screen_set_desktop(guint num, gboolean dofocus);
|
void screen_set_desktop(guint num, gboolean dofocus);
|
||||||
|
/*! Add a new desktop either at the end or inserted at the current desktop */
|
||||||
|
void screen_add_desktop(gboolean current);
|
||||||
|
/*! Remove a desktop, either at the end or the current desktop */
|
||||||
|
void screen_remove_desktop(gboolean current);
|
||||||
|
|
||||||
/*! Interactively change desktops */
|
/*! Interactively change desktops */
|
||||||
guint screen_cycle_desktop(ObDirection dir, gboolean wrap, gboolean linear,
|
guint screen_cycle_desktop(ObDirection dir, gboolean wrap, gboolean linear,
|
||||||
gboolean dialog, gboolean done, gboolean cancel);
|
gboolean dialog, gboolean done, gboolean cancel);
|
||||||
|
|
Loading…
Reference in a new issue