launch things on the desktop where you ran it.
also: kde apps move themselves to the current desktop when they open. what the heck?
This commit is contained in:
parent
c4446bebff
commit
ba161e967b
3 changed files with 10 additions and 3 deletions
|
@ -1109,6 +1109,9 @@ void action_execute(union ActionData *data)
|
||||||
env = sn_get_spawn_environment(program,
|
env = sn_get_spawn_environment(program,
|
||||||
data->execute.name,
|
data->execute.name,
|
||||||
data->execute.icon_name,
|
data->execute.icon_name,
|
||||||
|
/* launch it on the current
|
||||||
|
desktop */
|
||||||
|
screen_desktop,
|
||||||
data->execute.any.time);
|
data->execute.any.time);
|
||||||
if (!g_spawn_async(NULL, argv, env, G_SPAWN_SEARCH_PATH |
|
if (!g_spawn_async(NULL, argv, env, G_SPAWN_SEARCH_PATH |
|
||||||
G_SPAWN_DO_NOT_REAP_CHILD,
|
G_SPAWN_DO_NOT_REAP_CHILD,
|
||||||
|
|
|
@ -33,7 +33,7 @@ Time sn_app_started(const gchar *id, const gchar *wmclass)
|
||||||
}
|
}
|
||||||
gboolean sn_get_desktop(gchar *id, guint *desktop) { return FALSE; }
|
gboolean sn_get_desktop(gchar *id, guint *desktop) { return FALSE; }
|
||||||
gchar **sn_get_spawn_environment(char *program, char *name,
|
gchar **sn_get_spawn_environment(char *program, char *name,
|
||||||
char *icon_name, Time time)
|
char *icon_name, gint desktop, Time time)
|
||||||
{
|
{
|
||||||
return g_strdupv(environ);
|
return g_strdupv(environ);
|
||||||
}
|
}
|
||||||
|
@ -227,7 +227,8 @@ static gboolean sn_launch_wait_timeout(gpointer data)
|
||||||
}
|
}
|
||||||
|
|
||||||
gchar **sn_get_spawn_environment(char *program, char *name,
|
gchar **sn_get_spawn_environment(char *program, char *name,
|
||||||
char *icon_name, Time time)
|
char *icon_name, gint desktop,
|
||||||
|
Time time)
|
||||||
{
|
{
|
||||||
gchar **env, *desc;
|
gchar **env, *desc;
|
||||||
guint len;
|
guint len;
|
||||||
|
@ -244,6 +245,8 @@ gchar **sn_get_spawn_environment(char *program, char *name,
|
||||||
sn_launcher_context_set_description(sn_launcher, desc);
|
sn_launcher_context_set_description(sn_launcher, desc);
|
||||||
sn_launcher_context_set_icon_name(sn_launcher, icon_name ? icon_name : program);
|
sn_launcher_context_set_icon_name(sn_launcher, icon_name ? icon_name : program);
|
||||||
sn_launcher_context_set_binary_name(sn_launcher, program);
|
sn_launcher_context_set_binary_name(sn_launcher, program);
|
||||||
|
if (desktop >= 0 && (unsigned) desktop < screen_num_desktops)
|
||||||
|
sn_launcher_context_set_workspace(sn_launcher, (signed) desktop);
|
||||||
sn_launcher_context_initiate(sn_launcher, "openbox", program, time);
|
sn_launcher_context_initiate(sn_launcher, "openbox", program, time);
|
||||||
id = sn_launcher_context_get_startup_id(sn_launcher);
|
id = sn_launcher_context_get_startup_id(sn_launcher);
|
||||||
|
|
||||||
|
|
|
@ -36,7 +36,8 @@ gboolean sn_get_desktop(gchar *id, guint *desktop);
|
||||||
|
|
||||||
/* Get the environment to run the program in, with startup notification */
|
/* Get the environment to run the program in, with startup notification */
|
||||||
gchar **sn_get_spawn_environment(char *program, char *name,
|
gchar **sn_get_spawn_environment(char *program, char *name,
|
||||||
char *icon_name, Time time);
|
char *icon_name, gint desktop,
|
||||||
|
Time time);
|
||||||
|
|
||||||
/* Tell startup notification we're not actually running the program we
|
/* Tell startup notification we're not actually running the program we
|
||||||
told it we were
|
told it we were
|
||||||
|
|
Loading…
Reference in a new issue