all repos — openbox @ c5f01fd310d65b027858e78cd86b4b2585a12d4a

openbox fork - make it a bit more like ryudo

openbox/actions/session.c (raw)

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
#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
        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, NULL);

    return FALSE;
}