From 821e3e7e2cf1f301f83b790d66452913f92324ef Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Sat, 10 Oct 2015 22:25:56 +0200 Subject: [PATCH] Make awesome.quit() during startup work Signed-off-by: Uli Schlachter --- awesome.c | 9 ++++++--- luaa.c | 2 ++ 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/awesome.c b/awesome.c index 3033295af..fcde59cb3 100644 --- a/awesome.c +++ b/awesome.c @@ -610,9 +610,12 @@ main(int argc, char **argv) g_main_context_set_poll_func(g_main_context_default(), &a_glib_poll); gettimeofday(&last_wakeup, NULL); - /* main event loop */ - globalconf.loop = g_main_loop_new(NULL, FALSE); - g_main_loop_run(globalconf.loop); + /* main event loop (if not NULL, awesome.quit() was already called) */ + if (globalconf.loop == NULL) + { + globalconf.loop = g_main_loop_new(NULL, FALSE); + g_main_loop_run(globalconf.loop); + } g_main_loop_unref(globalconf.loop); globalconf.loop = NULL; diff --git a/luaa.c b/luaa.c index 8def66c79..6cc7d6432 100644 --- a/luaa.c +++ b/luaa.c @@ -107,6 +107,8 @@ composite_manager_running(void) static int luaA_quit(lua_State *L) { + if (globalconf.loop == NULL) + globalconf.loop = g_main_loop_new(NULL, FALSE); g_main_loop_quit(globalconf.loop); return 0; }