summaryrefslogtreecommitdiff
path: root/openbox/actions
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2009-12-08 14:19:04 -0500
committerDana Jansens <danakj@orodu.net>2009-12-08 14:19:04 -0500
commit2f09e0ce388f63c341cb328d795766e2bd0dc24b (patch)
tree14fb36919947e80ba0dfc151d0f1f02ed46fd712 /openbox/actions
parent84843c3f9842046e34366202f1a8f80ce8565f91 (diff)
parent672aea85cfe2ac2bc8cb4e3f34fd023f10d90182 (diff)
Merge branch 'backport' into work
Conflicts: openbox/actions/all.h openbox/actions/session.c openbox/client.c openbox/event.c openbox/grab.c
Diffstat (limited to 'openbox/actions')
-rw-r--r--openbox/actions/all.c1
-rw-r--r--openbox/actions/all.h1
-rw-r--r--openbox/actions/exit.c26
3 files changed, 21 insertions, 7 deletions
diff --git a/openbox/actions/all.c b/openbox/actions/all.c
index 952d756d..4563e65f 100644
--- a/openbox/actions/all.c
+++ b/openbox/actions/all.c
@@ -9,7 +9,6 @@ void action_all_startup(void)
action_reconfigure_startup();
action_exit_startup();
action_restart_startup();
- action_session_startup();
action_cyclewindows_startup();
action_breakchroot_startup();
action_close_startup();
diff --git a/openbox/actions/all.h b/openbox/actions/all.h
index 1f520b93..6acbc9ca 100644
--- a/openbox/actions/all.h
+++ b/openbox/actions/all.h
@@ -10,7 +10,6 @@ void action_showdesktop_startup(void);
void action_reconfigure_startup(void);
void action_exit_startup(void);
void action_restart_startup(void);
-void action_session_startup(void);
void action_cyclewindows_startup(void);
void action_breakchroot_startup(void);
void action_close_startup(void);
diff --git a/openbox/actions/exit.c b/openbox/actions/exit.c
index 4f8cce6e..3bfebbce 100644
--- a/openbox/actions/exit.c
+++ b/openbox/actions/exit.c
@@ -1,6 +1,7 @@
#include "openbox/actions.h"
#include "openbox/openbox.h"
#include "openbox/prompt.h"
+#include "openbox/session.h"
#include "gettext.h"
typedef struct {
@@ -13,6 +14,7 @@ static gboolean run_func(ObActionsData *data, gpointer options);
void action_exit_startup(void)
{
actions_register("Exit", setup_func, NULL, run_func, NULL, NULL);
+ actions_register("SessionLogout", setup_func, NULL, run_func, NULL, NULL);
}
static gpointer setup_func(xmlNodePtr node)
@@ -29,10 +31,18 @@ static gpointer setup_func(xmlNodePtr node)
return 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)
- ob_exit(0);
+ do_exit();
return TRUE; /* call the cleanup func */
}
@@ -53,13 +63,19 @@ static gboolean run_func(ObActionsData *data, gpointer options)
{ _("Exit"), 1 }
};
- p = prompt_new(_("Are you sure you want to exit Openbox?"),
- _("Exit Openbox"),
- answers, 2, 0, 0, prompt_cb, prompt_cleanup, NULL);
+ 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
- ob_exit(0);
+ do_exit();
return FALSE;
}