aboutsummaryrefslogtreecommitdiff
path: root/swaybar/tray
diff options
context:
space:
mode:
authorIan Fan <ianfan0@gmail.com>2019-02-16 11:02:15 +0000
committeremersion <contact@emersion.fr>2019-02-16 21:49:16 +0100
commitf54077dbca2faf3f0d614377a01a215c82ef075e (patch)
tree159afadf20fef694e827213458a5a5caf4195112 /swaybar/tray
parent26d6360febeb364a9c7e20844ad03c796e4f08c3 (diff)
tray: fix memory leaks
Diffstat (limited to 'swaybar/tray')
-rw-r--r--swaybar/tray/item.c6
-rw-r--r--swaybar/tray/watcher.c4
2 files changed, 7 insertions, 3 deletions
diff --git a/swaybar/tray/item.c b/swaybar/tray/item.c
index 4262d687..4fa6c97b 100644
--- a/swaybar/tray/item.c
+++ b/swaybar/tray/item.c
@@ -299,6 +299,8 @@ void destroy_sni(struct swaybar_sni *sni) {
return;
}
+ cairo_surface_destroy(sni->icon);
+
sd_bus_slot_unref(sni->new_icon_slot);
sd_bus_slot_unref(sni->new_attention_icon_slot);
sd_bus_slot_unref(sni->new_status_slot);
@@ -308,9 +310,11 @@ void destroy_sni(struct swaybar_sni *sni) {
free(sni->path);
free(sni->status);
free(sni->icon_name);
- free(sni->icon_pixmap);
+ list_free_items_and_destroy(sni->icon_pixmap);
free(sni->attention_icon_name);
+ list_free_items_and_destroy(sni->attention_icon_pixmap);
free(sni->menu);
+ free(sni->icon_theme_path);
free(sni);
}
diff --git a/swaybar/tray/watcher.c b/swaybar/tray/watcher.c
index 432837d0..951a0589 100644
--- a/swaybar/tray/watcher.c
+++ b/swaybar/tray/watcher.c
@@ -186,8 +186,8 @@ struct swaybar_watcher *create_watcher(char *protocol, sd_bus *bus) {
goto error;
}
- sd_bus_slot_set_floating(signal_slot, 1);
- sd_bus_slot_set_floating(vtable_slot, 1);
+ sd_bus_slot_set_floating(signal_slot, 0);
+ sd_bus_slot_set_floating(vtable_slot, 0);
watcher->bus = bus;
watcher->hosts = create_list();