summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFurkan Sahin <furkan-dev@proton.me>2017-04-07 07:55:35 -0400
committerFurkan Sahin <furkan-dev@proton.me>2017-04-07 07:55:35 -0400
commit9b7e2d6d1ed6a626ce036290c97757ced5b1ab20 (patch)
tree369745f450eccd1b578fb60e42fa8d29daeff7c2
parentbed22342fcdf53446d4a0121cbfaf9f2c5681f8e (diff)
Fix dangling file descriptors (fixes #1152)
-rw-r--r--sway/ipc-server.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/sway/ipc-server.c b/sway/ipc-server.c
index 0cacc515..3600cab2 100644
--- a/sway/ipc-server.c
+++ b/sway/ipc-server.c
@@ -161,7 +161,8 @@ int ipc_handle_connection(int fd, uint32_t mask, void *data) {
}
int flags;
- if ((flags=fcntl(client_fd, F_GETFD)) == -1 || fcntl(client_fd, F_SETFD, flags|FD_CLOEXEC) == -1) {
+ if ((flags = fcntl(client_fd, F_GETFD)) == -1
+ || fcntl(client_fd, F_SETFD, flags|FD_CLOEXEC) == -1) {
sway_log_errno(L_ERROR, "Unable to set CLOEXEC on IPC client socket");
close(client_fd);
return 0;
@@ -199,6 +200,8 @@ int ipc_client_handle_readable(int client_fd, uint32_t mask, void *data) {
}
if (mask & WLC_EVENT_HANGUP) {
+ sway_log(L_DEBUG, "Client %d hung up", client->fd);
+ close(client->fd);
client->fd = -1;
ipc_client_disconnect(client);
return 0;