X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Factions%2Fexit.c;h=2d9fc63312dc9c73b196474db71fb0f79bd99f83;hb=5e282dae08be3b900e0337efa0fae8f3ffa92cd7;hp=68b5cef4a5e94287c6af8e5f0fb1e6d579523c00;hpb=5d57a39b702a0f198c8a180a20058e3c82615523;p=chaz%2Fopenbox diff --git a/openbox/actions/exit.c b/openbox/actions/exit.c index 68b5cef4..2d9fc633 100644 --- a/openbox/actions/exit.c +++ b/openbox/actions/exit.c @@ -1,20 +1,88 @@ #include "openbox/actions.h" #include "openbox/openbox.h" +#include "openbox/prompt.h" +#include "openbox/session.h" +#include "gettext.h" +typedef struct { + gboolean prompt; +} Options; + +static gpointer setup_func(xmlNodePtr node); +static void free_func(gpointer o); static gboolean run_func(ObActionsData *data, gpointer options); -void action_exit_startup() +void action_exit_startup(void) +{ + actions_register("Exit", setup_func, free_func, run_func); + actions_register("SessionLogout", setup_func, free_func, run_func); +} + +static gpointer setup_func(xmlNodePtr node) +{ + xmlNodePtr n; + Options *o; + + o = g_slice_new0(Options); + o->prompt = TRUE; + + if ((n = obt_xml_find_node(node, "prompt"))) + o->prompt = obt_xml_node_bool(n); + + return o; +} + +static void free_func(gpointer o) { - actions_register("Exit", - NULL, NULL, - run_func, - NULL, NULL); + g_slice_free(Options, o); } +static void do_exit(void) +{ + if (session_connected()) + session_request_logout(FALSE); + else + ob_exit(0); +} + +static gboolean prompt_cb(ObPrompt *p, gint result, gpointer data) +{ + if (result) + do_exit(); + return TRUE; /* call the cleanup func */ +} + +static void prompt_cleanup(ObPrompt *p, gpointer data) +{ + prompt_unref(p); +} + + /* Always return FALSE because its not interactive */ static gboolean run_func(ObActionsData *data, gpointer options) { - ob_exit(0); + Options *o = options; + + if (o->prompt) { + ObPrompt *p; + ObPromptAnswer answers[] = { + { _("Cancel"), 0 }, + { _("Exit"), 1 } + }; + + if (session_connected()) + p = prompt_new(_("Are you sure you want to log out?"), + _("Log Out"), + answers, 2, 0, 0, prompt_cb, prompt_cleanup, NULL); + else + p = prompt_new(_("Are you sure you want to exit Openbox?"), + _("Exit Openbox"), + answers, 2, 0, 0, prompt_cb, prompt_cleanup, NULL); + + prompt_show(p, NULL, FALSE); + } + else + do_exit(); return FALSE; }