1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

fixing leakings

This commit is contained in:
David 2016-03-12 16:55:52 +01:00
parent 82de077b02
commit 520eee23a9
2 changed files with 36 additions and 4 deletions

View File

@ -43,9 +43,19 @@ static GtkStatusIcon *prof_tray = NULL;
static GString *icon_filename = NULL; static GString *icon_filename = NULL;
static GString *icon_msg_filename = NULL; static GString *icon_msg_filename = NULL;
static gint unread_messages; static gint unread_messages;
static bool shutting_down; static gboolean shutting_down;
static guint timer; static guint timer;
/* {{{ Privates */
/*
* Get icons from installation share folder or (if defined) .locale user's folder
*
* As implementation, looking through all the entries in the .locale folder is chosen.
* While useless as now, it might be useful in case an association name-icon is created.
* As now, with 2 icons only, this is pretty useless, but it is not harming ;)
*
*/
static void _get_icons(void) static void _get_icons(void)
{ {
GString *icons_dir = NULL; GString *icons_dir = NULL;
@ -74,26 +84,34 @@ static void _get_icons(void)
GString *name = g_string_new(g_dir_read_name(dir)); GString *name = g_string_new(g_dir_read_name(dir));
while (name->len) { while (name->len) {
if (g_strcmp0("proIcon.png", name->str) == 0) { if (g_strcmp0("proIcon.png", name->str) == 0) {
g_string_free(icon_filename, true);
icon_filename = g_string_new(icons_dir->str); icon_filename = g_string_new(icons_dir->str);
g_string_append(icon_filename, "/proIcon.png"); g_string_append(icon_filename, "/proIcon.png");
} else } else
if (g_strcmp0("proIconMsg.png", name->str) == 0){ if (g_strcmp0("proIconMsg.png", name->str) == 0){
g_string_free(icon_msg_filename, true);
icon_msg_filename = g_string_new(icons_dir->str); icon_msg_filename = g_string_new(icons_dir->str);
g_string_append(icon_msg_filename, "/proIconMsg.png"); g_string_append(icon_msg_filename, "/proIconMsg.png");
} }
g_string_free(name, true); g_string_free(name, true);
name = g_string_new(g_dir_read_name(dir)); name = g_string_new(g_dir_read_name(dir));
} }
g_string_free(name, true);
} else { } else {
fprintf (stderr, "Unable to open dir: %s\n", err->message); fprintf (stderr, "Unable to open dir: %s\n", err->message);
g_error_free(err); g_error_free(err);
} }
g_dir_close(dir); g_dir_close(dir);
g_free(err);
g_string_free(icons_dir, true); g_string_free(icons_dir, true);
} }
gboolean tray_change_icon(gpointer data) /*
* Callback for the timer
*
* This is the callback that the timer is calling in order to check if messages are there.
*
*/
gboolean _tray_change_icon(gpointer data)
{ {
if (shutting_down) { if (shutting_down) {
return false; return false;
@ -110,12 +128,15 @@ gboolean tray_change_icon(gpointer data)
return true; return true;
} }
/* }}} */
/* {{{ Public */
void create_tray(void) void create_tray(void)
{ {
_get_icons(); _get_icons();
prof_tray = gtk_status_icon_new_from_file(icon_filename->str); prof_tray = gtk_status_icon_new_from_file(icon_filename->str);
shutting_down = false; shutting_down = false;
timer = g_timeout_add(5000, tray_change_icon, NULL); timer = g_timeout_add(5000, _tray_change_icon, NULL);
} }
void destroy_tray(void) void destroy_tray(void)
@ -129,3 +150,5 @@ void destroy_tray(void)
g_string_free(icon_filename, true); g_string_free(icon_filename, true);
g_string_free(icon_msg_filename, true); g_string_free(icon_msg_filename, true);
} }
/* }}} */

View File

@ -35,7 +35,16 @@
#ifndef PROFANITY_TRAY_H #ifndef PROFANITY_TRAY_H
#define PROFANITY_TRAY_H #define PROFANITY_TRAY_H
/*
* Create tray icon
*
* This will initialize the timer that will be called in order to change the icons
* and will search the icons in the defaults paths
*/
void create_tray(void); void create_tray(void);
/*
* Destroy tray icon
*/
void destroy_tray(void); void destroy_tray(void);
#endif #endif