]> Dogcows Code - chaz/openbox/blob - openbox/actions/execute.c
Don't hilite new windows when we're restoring them from a saved session.
[chaz/openbox] / openbox / actions / execute.c
1 #include "openbox/actions.h"
2 #include "openbox/event.h"
3 #include "openbox/startupnotify.h"
4 #include "openbox/prompt.h"
5 #include "openbox/screen.h"
6 #include "gettext.h"
7
8 #ifdef HAVE_STDLIB_H
9 # include <stdlib.h>
10 #endif
11
12 typedef struct {
13 gchar *cmd;
14 gboolean sn;
15 gchar *sn_name;
16 gchar *sn_icon;
17 gchar *sn_wmclass;
18 gchar *prompt;
19 } Options;
20
21 static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node);
22 static void free_func(gpointer options);
23 static gboolean run_func(ObActionsData *data, gpointer options);
24 /*
25 static gboolean i_input_func(guint initial_state,
26 XEvent *e,
27 gpointer options,
28 gboolean *used);
29 static void i_cancel_func(gpointer options);
30 */
31
32 void action_execute_startup(void)
33 {
34 actions_register("Execute",
35 setup_func,
36 free_func,
37 run_func,
38 NULL, NULL);
39 }
40
41 static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node)
42 {
43 xmlNodePtr n;
44 Options *o;
45
46 o = g_new0(Options, 1);
47
48 if ((n = parse_find_node("command", node)) ||
49 (n = parse_find_node("execute", node)))
50 {
51 gchar *s = parse_string(doc, n);
52 o->cmd = parse_expand_tilde(s);
53 g_free(s);
54 }
55
56 if ((n = parse_find_node("prompt", node)))
57 o->prompt = parse_string(doc, n);
58
59 if ((n = parse_find_node("startupnotify", node))) {
60 xmlNodePtr m;
61 if ((m = parse_find_node("enabled", n->xmlChildrenNode)))
62 o->sn = parse_bool(doc, m);
63 if ((m = parse_find_node("name", n->xmlChildrenNode)))
64 o->sn_name = parse_string(doc, m);
65 if ((m = parse_find_node("icon", n->xmlChildrenNode)))
66 o->sn_icon = parse_string(doc, m);
67 if ((m = parse_find_node("wmclass", n->xmlChildrenNode)))
68 o->sn_wmclass = parse_string(doc, m);
69 }
70 return o;
71 }
72
73 static void free_func(gpointer options)
74 {
75 Options *o = options;
76
77 if (o) {
78 g_free(o->cmd);
79 g_free(o->sn_name);
80 g_free(o->sn_icon);
81 g_free(o->sn_wmclass);
82 g_free(o->prompt);
83 g_free(o);
84 }
85 }
86
87 static Options* dup_options(Options *in)
88 {
89 Options *o = g_new(Options, 1);
90 o->cmd = g_strdup(in->cmd);
91 o->sn = in->sn;
92 o->sn_name = g_strdup(in->sn_name);
93 o->sn_icon = g_strdup(in->sn_icon);
94 o->sn_wmclass = g_strdup(in->sn_wmclass);
95 o->prompt = NULL;
96 return o;
97 }
98
99 static gboolean run_func(ObActionsData *data, gpointer options);
100
101 static gboolean prompt_cb(ObPrompt *p, gint result, gpointer options)
102 {
103 if (result)
104 run_func(NULL, options);
105 return TRUE; /* call the cleanup func */
106 }
107
108 static void prompt_cleanup(ObPrompt *p, gpointer options)
109 {
110 prompt_unref(p);
111 free_func(options);
112 }
113
114 /* Always return FALSE because its not interactive */
115 static gboolean run_func(ObActionsData *data, gpointer options)
116 {
117 GError *e = NULL;
118 gchar **argv = NULL;
119 gchar *cmd;
120 Options *o = options;
121
122 if (!o->cmd) return FALSE;
123
124 if (o->prompt) {
125 ObPrompt *p;
126 Options *ocp;
127 ObPromptAnswer answers[] = {
128 { _("No"), 0 },
129 { _("Yes"), 1 }
130 };
131
132 ocp = dup_options(options);
133 p = prompt_new(o->prompt, _("Execute"), answers, 2, 0, 0,
134 prompt_cb, prompt_cleanup, ocp);
135 prompt_show(p, NULL, FALSE);
136
137 return FALSE;
138 }
139
140 cmd = g_filename_from_utf8(o->cmd, -1, NULL, NULL, NULL);
141 if (!cmd) {
142 g_message(_("Failed to convert the path \"%s\" from utf8"), o->cmd);
143 return FALSE;
144 }
145
146 /* If there is a keyboard grab going on then we need to cancel
147 it so the application can grab things */
148 event_cancel_all_key_grabs();
149
150 if (!g_shell_parse_argv(cmd, NULL, &argv, &e)) {
151 g_message(e->message, o->cmd);
152 g_error_free(e);
153 }
154 else {
155 gchar *program = NULL;
156
157 if (o->sn) {
158 program = g_path_get_basename(argv[0]);
159 /* sets up the environment */
160 sn_setup_spawn_environment(program, o->sn_name, o->sn_icon,
161 o->sn_wmclass,
162 /* launch it on the current desktop */
163 screen_desktop);
164 }
165
166 if (!g_spawn_async(NULL, argv, NULL,
167 G_SPAWN_SEARCH_PATH | G_SPAWN_DO_NOT_REAP_CHILD,
168 NULL, NULL, NULL, &e))
169 {
170 g_message(e->message, o->cmd);
171 g_error_free(e);
172
173 if (o->sn)
174 sn_spawn_cancel();
175 }
176 if (o->sn)
177 unsetenv("DESKTOP_STARTUP_ID");
178
179 g_free(program);
180 g_strfreev(argv);
181 }
182
183 g_free(cmd);
184
185 return FALSE;
186 }
This page took 0.042443 seconds and 4 git commands to generate.