[evolution-data-server] Bug #630361 - Categories editing fixes



commit 6863f2c1b05b7e3ae2b82ba6e98c86542ba2a6e5
Author: Milan Crha <mcrha redhat com>
Date:   Thu Oct 7 13:49:47 2010 +0200

    Bug #630361 - Categories editing fixes

 libedataserver/e-categories.c          |   63 +++++++++++++++++++++++---------
 libedataserverui/e-categories-dialog.c |   24 +++++++++++-
 2 files changed, 67 insertions(+), 20 deletions(-)
---
diff --git a/libedataserver/e-categories.c b/libedataserver/e-categories.c
index b079534..b6b50fc 100644
--- a/libedataserver/e-categories.c
+++ b/libedataserver/e-categories.c
@@ -35,6 +35,7 @@ typedef struct {
 	gchar *clocale_name;  /* only for default categories */
 	gchar *icon_file;
 	gboolean is_default;
+	gboolean is_searchable;
 } CategoryInfo;
 
 typedef struct {
@@ -194,7 +195,7 @@ hash_to_xml_string (gpointer key, gpointer value, gpointer user_data)
 
 	g_string_append_len (string, "  <category", 11);
 
-	if (cat_info->is_default)
+	if (cat_info->is_default && cat_info->clocale_name && *cat_info->clocale_name)
 		category = escape_string (cat_info->clocale_name);
 	else
 		category = escape_string (cat_info->display_name);
@@ -206,7 +207,10 @@ hash_to_xml_string (gpointer key, gpointer value, gpointer user_data)
 			string, " icon=\"%s\"", cat_info->icon_file);
 
 	g_string_append_printf (
-		string, " default=\"%d\"", cat_info->is_default);
+		string, " default=\"%d\"", cat_info->is_default ? 1 : 0);
+
+	g_string_append_printf (
+		string, " searchable=\"%d\"", cat_info->is_searchable ? 1 : 0);
 
 	g_string_append_len (string, "/>\n", 3);
 }
@@ -264,10 +268,27 @@ save_categories (void)
 		idle_id = g_idle_add (idle_saver_cb, NULL);
 }
 
+static gchar *
+get_collation_key (const gchar *category)
+{
+	gchar *casefolded, *key;
+
+	g_return_val_if_fail (category != NULL, NULL);
+
+	casefolded = g_utf8_casefold (category, -1);
+	g_return_val_if_fail (casefolded != NULL, NULL);
+
+	key = g_utf8_collate_key (casefolded, -1);
+	g_free (casefolded);
+
+	return key;
+}
+
 static void
 categories_add_full (const gchar *category,
                      const gchar *icon_file,
-                     gboolean is_default)
+                     gboolean is_default,
+		     gboolean is_searchable)
 {
 	CategoryInfo *cat_info;
 	gchar *collation_key;
@@ -284,8 +305,9 @@ categories_add_full (const gchar *category,
 	}
 	cat_info->icon_file = g_strdup (icon_file);
 	cat_info->is_default = is_default;
+	cat_info->is_searchable = is_default || is_searchable;
 
-	collation_key = g_utf8_collate_key (cat_info->display_name, -1);
+	collation_key = get_collation_key (cat_info->display_name);
 	g_hash_table_insert (categories_table, collation_key, cat_info);
 
 	changed = TRUE;
@@ -298,7 +320,7 @@ categories_lookup (const gchar *category)
 	CategoryInfo *cat_info;
 	gchar *collation_key;
 
-	collation_key = g_utf8_collate_key (category, -1);
+	collation_key = get_collation_key (category);
 	cat_info = g_hash_table_lookup (categories_table, collation_key);
 	g_free (collation_key);
 
@@ -326,27 +348,25 @@ parse_categories (const gchar *contents, gsize length)
 	}
 
 	for (node = node->xmlChildrenNode; node != NULL; node = node->next) {
-		xmlChar *category, *icon_file, *is_default;
+		xmlChar *category, *icon_file, *is_default, *is_searchable;
 
 		category = xmlGetProp (node, (xmlChar *) "a");
 		icon_file = xmlGetProp (node, (xmlChar *) "icon");
 		is_default = xmlGetProp (node, (xmlChar *) "default");
+		is_searchable = xmlGetProp (node, (xmlChar *) "searchable");
 
-		/* Default categories used to be called "searchable". */
-		if (is_default == NULL)
-			is_default = xmlGetProp (
-				node, (xmlChar *) "searchable");
-
-		if (category != NULL) {
+		if (category != NULL && *category) {
 			categories_add_full (
 				(gchar *) category, (gchar *) icon_file,
-				g_strcmp0 ((gchar *) is_default, "1") == 0);
+				g_strcmp0 ((gchar *) is_default, "1") == 0,
+				g_strcmp0 ((gchar *) is_searchable, "1") == 0);
 			n_added++;
 		}
 
 		xmlFree (category);
 		xmlFree (icon_file);
 		xmlFree (is_default);
+		xmlFree (is_searchable);
 	}
 
 	xmlFreeDoc (doc);
@@ -456,7 +476,7 @@ load_default_categories (void)
 				E_DATA_SERVER_IMAGESDIR,
 				cat_info->icon_file, NULL);
 
-		categories_add_full (cat_info->category, icon_file, TRUE);
+		categories_add_full (cat_info->category, icon_file, TRUE, TRUE);
 
 		g_free (icon_file);
 		cat_info++;
@@ -573,11 +593,12 @@ e_categories_add (const gchar *category,
                   gboolean searchable)
 {
 	g_return_if_fail (category != NULL);
+	g_return_if_fail (*category);
 
 	if (!initialized)
 		initialize_categories ();
 
-	categories_add_full (category, icon_file, FALSE);
+	categories_add_full (category, icon_file, FALSE, searchable);
 }
 
 /**
@@ -589,15 +610,21 @@ e_categories_add (const gchar *category,
 void
 e_categories_remove (const gchar *category)
 {
+	gchar *collation_key;
+
 	g_return_if_fail (category != NULL);
 
 	if (!initialized)
 		initialize_categories ();
 
-	if (g_hash_table_remove (categories_table, category)) {
+	collation_key = get_collation_key (category);
+
+	if (g_hash_table_remove (categories_table, collation_key)) {
 		changed = TRUE;
 		save_categories ();
 	}
+
+	g_free (collation_key);
 }
 
 /**
@@ -616,7 +643,7 @@ e_categories_exist (const gchar *category)
 	if (!initialized)
 		initialize_categories ();
 
-	return (categories_lookup (category) != NULL);
+	return (!*category) || (categories_lookup (category) != NULL);
 }
 
 /**
@@ -694,7 +721,7 @@ e_categories_is_searchable (const gchar *category)
 	if (cat_info == NULL)
 		return FALSE;
 
-	return cat_info->is_default;
+	return cat_info->is_searchable;
 }
 
 /**
diff --git a/libedataserverui/e-categories-dialog.c b/libedataserverui/e-categories-dialog.c
index 151c9a1..8c2079a 100644
--- a/libedataserverui/e-categories-dialog.c
+++ b/libedataserverui/e-categories-dialog.c
@@ -100,6 +100,24 @@ file_chooser_response (GtkDialog *dialog, gint response_id, GtkFileChooser *butt
 	}
 }
 
+static void
+category_name_changed_cb (GtkEntry *category_name_entry, CategoryPropertiesDialog *prop_dialog)
+{
+	gchar *name;
+
+	g_return_if_fail (prop_dialog != NULL);
+	g_return_if_fail (prop_dialog->the_dialog != NULL);
+	g_return_if_fail (category_name_entry != NULL);
+
+	name = g_strdup (gtk_entry_get_text (category_name_entry));
+	if (name)
+		name = g_strstrip (name);
+
+	gtk_dialog_set_response_sensitive (GTK_DIALOG (prop_dialog->the_dialog), GTK_RESPONSE_OK, name && *name);
+
+	g_free (name);
+}
+
 static CategoryPropertiesDialog *
 load_properties_dialog (ECategoriesDialog *parent)
 {
@@ -138,6 +156,9 @@ load_properties_dialog (ECategoriesDialog *parent)
 	gtk_window_set_transient_for (GTK_WINDOW (prop_dialog->the_dialog), GTK_WINDOW (parent));
 
 	prop_dialog->category_name = GTK_WIDGET (gtk_builder_get_object (prop_dialog->gui, "category-name"));
+	g_signal_connect (prop_dialog->category_name, "changed", G_CALLBACK (category_name_changed_cb), prop_dialog);
+	category_name_changed_cb (GTK_ENTRY (prop_dialog->category_name), prop_dialog);
+
 	table = GTK_WIDGET (gtk_builder_get_object (prop_dialog->gui, "table-category-properties"));
 
 	if (table) {
@@ -336,8 +357,7 @@ check_category_name (const gchar *name)
 		p++;
 	}
 
-	p = str->str;
-	g_string_free (str, FALSE);
+	p = g_strstrip (g_string_free (str, FALSE));
 
 	return p;
 }



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]