support getting the desktop from the startup notification protocol
pass on to the startup notification code that a window has mapped with a given wmclass
This commit is contained in:
parent
038735d627
commit
e7b2e52b78
1 changed files with 33 additions and 40 deletions
|
@ -1,8 +1,8 @@
|
||||||
#include "debug.h"
|
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
|
#include "debug.h"
|
||||||
|
#include "startupnotify.h"
|
||||||
#include "dock.h"
|
#include "dock.h"
|
||||||
#include "xerror.h"
|
#include "xerror.h"
|
||||||
#include "startup.h"
|
|
||||||
#include "screen.h"
|
#include "screen.h"
|
||||||
#include "moveresize.h"
|
#include "moveresize.h"
|
||||||
#include "place.h"
|
#include "place.h"
|
||||||
|
@ -37,6 +37,7 @@ GSList *client_destructors = NULL;
|
||||||
|
|
||||||
static void client_get_all(ObClient *self);
|
static void client_get_all(ObClient *self);
|
||||||
static void client_toggle_border(ObClient *self, gboolean show);
|
static void client_toggle_border(ObClient *self, gboolean show);
|
||||||
|
static void client_get_startup_id(ObClient *self);
|
||||||
static void client_get_area(ObClient *self);
|
static void client_get_area(ObClient *self);
|
||||||
static void client_get_desktop(ObClient *self);
|
static void client_get_desktop(ObClient *self);
|
||||||
static void client_get_state(ObClient *self);
|
static void client_get_state(ObClient *self);
|
||||||
|
@ -165,35 +166,8 @@ void client_manage_all()
|
||||||
}
|
}
|
||||||
XFree(children);
|
XFree(children);
|
||||||
|
|
||||||
/* stack them as they were on startup!
|
if (config_focus_new)
|
||||||
why with stacking_lower? Why, because then windows who aren't in the
|
|
||||||
stacking list are on the top where you can see them instead of buried
|
|
||||||
at the bottom! */
|
|
||||||
for (i = startup_stack_size; i > 0; --i) {
|
|
||||||
ObWindow *obw;
|
|
||||||
|
|
||||||
w = startup_stack_order[i-1];
|
|
||||||
obw = g_hash_table_lookup(window_map, &w);
|
|
||||||
if (obw) {
|
|
||||||
g_assert(WINDOW_IS_CLIENT(obw));
|
|
||||||
stacking_lower(CLIENT_AS_WINDOW(obw));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
g_free(startup_stack_order);
|
|
||||||
startup_stack_order = NULL;
|
|
||||||
startup_stack_size = 0;
|
|
||||||
|
|
||||||
if (config_focus_new) {
|
|
||||||
ObWindow *active;
|
|
||||||
|
|
||||||
active = g_hash_table_lookup(window_map, &startup_active);
|
|
||||||
if (active) {
|
|
||||||
g_assert(WINDOW_IS_CLIENT(active));
|
|
||||||
if (!client_focus(WINDOW_AS_CLIENT(active)))
|
|
||||||
focus_fallback(OB_FOCUS_FALLBACK_NOFOCUS);
|
focus_fallback(OB_FOCUS_FALLBACK_NOFOCUS);
|
||||||
} else
|
|
||||||
focus_fallback(OB_FOCUS_FALLBACK_NOFOCUS);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void client_manage(Window window)
|
void client_manage(Window window)
|
||||||
|
@ -251,9 +225,18 @@ void client_manage(Window window)
|
||||||
self->obwin.type = Window_Client;
|
self->obwin.type = Window_Client;
|
||||||
self->window = window;
|
self->window = window;
|
||||||
|
|
||||||
|
/* non-zero defaults */
|
||||||
|
self->title_count = 1;
|
||||||
|
self->wmstate = NormalState;
|
||||||
|
self->layer = -1;
|
||||||
|
self->decorate = TRUE;
|
||||||
|
self->desktop = screen_num_desktops; /* always an invalid value */
|
||||||
|
|
||||||
client_get_all(self);
|
client_get_all(self);
|
||||||
client_restore_session_state(self);
|
client_restore_session_state(self);
|
||||||
|
|
||||||
|
sn_app_started(self->class);
|
||||||
|
|
||||||
client_change_state(self);
|
client_change_state(self);
|
||||||
|
|
||||||
/* remove the client's border (and adjust re gravity) */
|
/* remove the client's border (and adjust re gravity) */
|
||||||
|
@ -669,15 +652,10 @@ static void client_toggle_border(ObClient *self, gboolean show)
|
||||||
|
|
||||||
static void client_get_all(ObClient *self)
|
static void client_get_all(ObClient *self)
|
||||||
{
|
{
|
||||||
/* non-zero defaults */
|
|
||||||
self->title_count = 1;
|
|
||||||
self->wmstate = NormalState;
|
|
||||||
self->layer = -1;
|
|
||||||
self->decorate = TRUE;
|
|
||||||
|
|
||||||
client_get_area(self);
|
client_get_area(self);
|
||||||
client_update_transient_for(self);
|
client_update_transient_for(self);
|
||||||
client_update_wmhints(self);
|
client_update_wmhints(self);
|
||||||
|
client_get_startup_id(self);
|
||||||
client_get_desktop(self);
|
client_get_desktop(self);
|
||||||
client_get_state(self);
|
client_get_state(self);
|
||||||
client_get_shaped(self);
|
client_get_shaped(self);
|
||||||
|
@ -701,6 +679,14 @@ static void client_get_all(ObClient *self)
|
||||||
client_update_icons(self);
|
client_update_icons(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void client_get_startup_id(ObClient *self)
|
||||||
|
{
|
||||||
|
if (!(PROP_GETS(self->window, net_startup_id, utf8, &self->startup_id)))
|
||||||
|
if (self->group)
|
||||||
|
PROP_GETS(self->group->leader,
|
||||||
|
net_startup_id, utf8, &self->startup_id);
|
||||||
|
}
|
||||||
|
|
||||||
static void client_get_area(ObClient *self)
|
static void client_get_area(ObClient *self)
|
||||||
{
|
{
|
||||||
XWindowAttributes wattrib;
|
XWindowAttributes wattrib;
|
||||||
|
@ -741,10 +727,17 @@ static void client_get_desktop(ObClient *self)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!trdesk)
|
if (!trdesk) {
|
||||||
|
/* try get from the startup-notification protocol */
|
||||||
|
if (sn_get_desktop(self->startup_id, &self->desktop)) {
|
||||||
|
if (self->desktop >= screen_num_desktops &&
|
||||||
|
self->desktop != DESKTOP_ALL)
|
||||||
|
self->desktop = screen_num_desktops - 1;
|
||||||
|
} else
|
||||||
/* defaults to the current desktop */
|
/* defaults to the current desktop */
|
||||||
self->desktop = screen_desktop;
|
self->desktop = screen_desktop;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (self->desktop != d) {
|
if (self->desktop != d) {
|
||||||
/* set the desktop hint, to make sure that it always exists */
|
/* set the desktop hint, to make sure that it always exists */
|
||||||
PROP_SET32(self->window, net_wm_desktop, cardinal, self->desktop);
|
PROP_SET32(self->window, net_wm_desktop, cardinal, self->desktop);
|
||||||
|
|
Loading…
Reference in a new issue