diff options
Diffstat (limited to 'openbox/actions')
| -rw-r--r-- | openbox/actions/all.c | 1 | ||||
| -rw-r--r-- | openbox/actions/all.h | 1 | ||||
| -rw-r--r-- | openbox/actions/exit.c | 26 |
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; } |
