1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
#include "openbox/actions.h"
#include "openbox/prompt.h"
#include "openbox/session.h"
#include "gettext.h"
typedef struct {
gboolean prompt;
gboolean silent;
} Options;
static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node);
static gboolean logout_func(ObActionsData *data, gpointer options);
void action_session_startup(void)
{
actions_register("SessionLogout", setup_func, NULL, logout_func,
NULL, NULL);
}
static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node)
{
xmlNodePtr n;
Options *o;
o = g_new0(Options, 1);
o->prompt = TRUE;
if ((n = parse_find_node("prompt", node)))
o->prompt = parse_bool(doc, n);
return o;
}
static gboolean prompt_cb(ObPrompt *p, gint result, gpointer data)
{
Options *o = data;
if (result) {
#ifdef USE_SM
session_request_logout(o->silent);
#else
/* TRANSLATORS: Don't translate the word "SessionLogout" as it's the
name of the action you write in rc.xml */
g_message(_("The SessionLogout action is not available since Openbox was built without session management support"));
#endif
}
return TRUE; /* call cleanup func */
}
static void prompt_cleanup(ObPrompt *p, gpointer data)
{
g_free(data);
prompt_unref(p);
}
/* Always return FALSE because its not interactive */
static gboolean logout_func(ObActionsData *data, gpointer options)
{
Options *o = options;
if (o->prompt) {
Options *o2;
ObPrompt *p;
ObPromptAnswer answers[] = {
{ _("Cancel"), 0 },
{ _("Log Out"), 1 }
};
o2 = g_memdup(o, sizeof(Options));
p = prompt_new(_("Are you sure you want to log out?"),
_("Log Out"),
answers, 2, 0, 0, prompt_cb, prompt_cleanup, o2);
prompt_show(p, NULL, FALSE);
}
else
prompt_cb(NULL, 1, o);
return FALSE;
}
|