aboutsummaryrefslogtreecommitdiff
path: root/sway
diff options
context:
space:
mode:
Diffstat (limited to 'sway')
-rw-r--r--sway/commands.c8
-rw-r--r--sway/container.c10
-rw-r--r--sway/handlers.c6
-rw-r--r--sway/main.c8
4 files changed, 24 insertions, 8 deletions
diff --git a/sway/commands.c b/sway/commands.c
index 0955db38..fe341cd5 100644
--- a/sway/commands.c
+++ b/sway/commands.c
@@ -318,12 +318,6 @@ static struct cmd_results *cmd_exec(int argc, char **argv) {
return cmd_exec_always(argc, argv);
}
-static void kill_views(swayc_t *container, void *data) {
- if (container->type == C_VIEW) {
- wlc_view_close(container->handle);
- }
-}
-
static struct cmd_results *cmd_exit(int argc, char **argv) {
struct cmd_results *error = NULL;
if (config->reading) return cmd_results_new(CMD_FAILURE, "exit", "Can't be used in config file.");
@@ -331,7 +325,7 @@ static struct cmd_results *cmd_exit(int argc, char **argv) {
return error;
}
// Close all views
- container_map(&root_container, kill_views, NULL);
+ close_views(&root_container);
sway_terminate();
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
}
diff --git a/sway/container.c b/sway/container.c
index e6fa4f37..dcf4dcc8 100644
--- a/sway/container.c
+++ b/sway/container.c
@@ -796,3 +796,13 @@ void add_gaps(swayc_t *view, void *_data) {
}
}
}
+
+static void close_view(swayc_t *container, void *data) {
+ if (container->type == C_VIEW) {
+ wlc_view_close(container->handle);
+ }
+}
+
+void close_views(swayc_t *container) {
+ container_map(container, close_view, NULL);
+}
diff --git a/sway/handlers.c b/sway/handlers.c
index b8bd9eff..6c6d0e60 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -252,8 +252,12 @@ static void handle_view_destroyed(wlc_handle handle) {
}
if (view) {
- swayc_t *parent = destroy_view(view);
+ bool fullscreen = swayc_is_fullscreen(view);
remove_view_from_scratchpad(view);
+ swayc_t *parent = destroy_view(view);
+ if (fullscreen) {
+ parent->fullscreen = NULL;
+ }
arrange_windows(parent, -1, -1);
} else {
// Is it unmanaged?
diff --git a/sway/main.c b/sway/main.c
index 382e7ca2..37681f2d 100644
--- a/sway/main.c
+++ b/sway/main.c
@@ -26,6 +26,11 @@ void sway_terminate(void) {
wlc_terminate();
}
+void sig_handler(int signal) {
+ close_views(&root_container);
+ sway_terminate();
+}
+
static void wlc_log_handler(enum wlc_log_type type, const char *str) {
if (type == WLC_LOG_ERROR) {
sway_log(L_ERROR, "[wlc] %s", str);
@@ -176,6 +181,9 @@ int main(int argc, char **argv) {
}
register_extensions();
+ // handle SIGTERM signals
+ signal(SIGTERM, sig_handler);
+
#if defined SWAY_GIT_VERSION && defined SWAY_GIT_BRANCH && defined SWAY_VERSION_DATE
sway_log(L_INFO, "Starting sway version %s (%s, branch \"%s\")\n", SWAY_GIT_VERSION, SWAY_VERSION_DATE, SWAY_GIT_BRANCH);
#endif