aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYaoBing Xiao <xiaoyaobing@uniontech.com>2025-06-05 13:46:06 +0800
committerSimon Ser <contact@emersion.fr>2025-06-08 21:10:25 +0200
commitf4a33dcab56c595bc8f923f4b8653814c4da4ed5 (patch)
tree3dc67f79a539cf604c9e863890228d71b03c62fe
parent8174ff2fe2b7dea3bf9f0830c7d745c7e199d894 (diff)
server: fix socket path memory leak
The socket path allocated with strdup() in server_init() was not being freed in server_fini(). Remove const qualifier and add proper cleanup. (cherry picked from commit 9fb9e9f7d555ae7504b8ae53250020797d70e887)
-rw-r--r--include/sway/server.h2
-rw-r--r--sway/server.c1
2 files changed, 2 insertions, 1 deletions
diff --git a/include/sway/server.h b/include/sway/server.h
index e7d7094f..1cb72e77 100644
--- a/include/sway/server.h
+++ b/include/sway/server.h
@@ -27,7 +27,7 @@ struct sway_session_lock {
struct sway_server {
struct wl_display *wl_display;
struct wl_event_loop *wl_event_loop;
- const char *socket;
+ char *socket;
struct wlr_backend *backend;
struct wlr_session *session;
diff --git a/sway/server.c b/sway/server.c
index 97976148..e8a6ce64 100644
--- a/sway/server.c
+++ b/sway/server.c
@@ -502,6 +502,7 @@ void server_fini(struct sway_server *server) {
wlr_backend_destroy(server->backend);
wl_display_destroy(server->wl_display);
list_free(server->dirty_nodes);
+ free(server->socket);
}
bool server_start(struct sway_server *server) {