changeset 15691:444b7ee76492

small leak/fix
author Richard Nelson <wabz@pidgin.im>
date Fri, 23 Feb 2007 21:46:52 +0000
parents dc01798f4c96
children acf21858f5e2
files console/libgnt/gntcolors.c
diffstat 1 files changed, 15 insertions(+), 7 deletions(-) [+]
line wrap: on
line diff
--- a/console/libgnt/gntcolors.c	Fri Feb 23 17:20:33 2007 +0000
+++ b/console/libgnt/gntcolors.c	Fri Feb 23 21:46:52 2007 +0000
@@ -161,7 +161,7 @@
 		while (nkeys--)
 		{
 			gsize len;
-			char *key = keys[nkeys];
+			gchar *key = keys[nkeys];
 			char **list = g_key_file_get_string_list(kfile, "colors", key, &len, NULL);
 			if (len == 3)
 			{
@@ -170,8 +170,9 @@
 				int b = atoi(list[2]);
 				int color = -1;
 
-				g_ascii_strdown(key, -1);
+				key = g_ascii_strdown(key, -1);
 				color = get_color(key);
+				g_free(key);
 				if (color == -1)
 					continue;
 
@@ -204,17 +205,21 @@
 	while (nkeys--)
 	{
 		gsize len;
-		char *key = keys[nkeys];
+		gchar *key = keys[nkeys];
 		char **list = g_key_file_get_string_list(kfile, "colorpairs", key, &len, NULL);
 		if (len == 2)
 		{
 			GntColorType type = 0;
-			int fg = get_color(g_ascii_strdown(list[0], -1));
-			int bg = get_color(g_ascii_strdown(list[1], -1));
+			gchar *fgc = g_ascii_strdown(list[0], -1);
+			gchar *bgc = g_ascii_strdown(list[1], -1);
+			int fg = get_color(fgc);
+			int bg = get_color(bgc);
+			g_free(fgc);
+			g_free(bgc);
 			if (fg == -1 || bg == -1)
 				continue;
 
-			g_ascii_strdown(key, -1);
+			key = g_ascii_strdown(key, -1);
 
 			if (strcmp(key, "normal") == 0)
 				type = GNT_COLOR_NORMAL;
@@ -234,8 +239,11 @@
 				type = GNT_COLOR_DISABLED;
 			else if (strcmp(key, "urgent") == 0)
 				type = GNT_COLOR_URGENT;
-			else
+			else {
+				g_free(key);
 				continue;
+			}
+			g_free(key);
 
 			init_pair(type, fg, bg);
 		}