commit f54077dbca2faf3f0d614377a01a215c82ef075e
parent 26d6360febeb364a9c7e20844ad03c796e4f08c3
Author: Ian Fan <ianfan0@gmail.com>
Date: Sat, 16 Feb 2019 11:02:15 +0000
tray: fix memory leaks
Diffstat:
2 files changed, 7 insertions(+), 3 deletions(-)
diff --git 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
@@ -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();