aboutsummaryrefslogtreecommitdiffstats
path: root/mail/em-vfolder-editor-rule.c
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2013-01-12 02:00:56 +0800
committerMatthew Barnes <mbarnes@redhat.com>2013-01-12 02:43:19 +0800
commitde978d42317423ceb3041d773913473d564a0ec4 (patch)
tree93caed2beebd7779ae5f6d35669d65cea0146469 /mail/em-vfolder-editor-rule.c
parentadc0ad91c4e187d814d41edd69a6c53c6405f235 (diff)
downloadgsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.tar
gsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.tar.gz
gsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.tar.bz2
gsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.tar.lz
gsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.tar.xz
gsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.tar.zst
gsoc2013-evolution-de978d42317423ceb3041d773913473d564a0ec4.zip
Use g_hash_table_add() when using a hash table as a set.
g_hash_table_add(table, key) uses less memory than g_hash_table_insert(table, key, GINT_TO_POINTER (1)). Also use g_hash_table_contains() when testing for membership.
Diffstat (limited to 'mail/em-vfolder-editor-rule.c')
-rw-r--r--mail/em-vfolder-editor-rule.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/mail/em-vfolder-editor-rule.c b/mail/em-vfolder-editor-rule.c
index 59c3713ed4..1319bdcee0 100644
--- a/mail/em-vfolder-editor-rule.c
+++ b/mail/em-vfolder-editor-rule.c
@@ -322,7 +322,11 @@ vfr_folder_response (EMFolderSelector *selector,
selection = gtk_tree_view_get_selection (data->tree_view);
gtk_tree_selection_unselect_all (selection);
- known_uris = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, NULL);
+ known_uris = g_hash_table_new_full (
+ (GHashFunc) g_str_hash,
+ (GEqualFunc) g_str_equal,
+ (GDestroyNotify) g_free,
+ (GDestroyNotify) NULL);
if (gtk_tree_model_get_iter_first (GTK_TREE_MODEL (data->model), &iter)) {
GtkTreeModel *model = GTK_TREE_MODEL (data->model);
@@ -332,7 +336,7 @@ vfr_folder_response (EMFolderSelector *selector,
gtk_tree_model_get (model, &iter, 1, &known, -1);
if (known)
- g_hash_table_insert (known_uris, known, GINT_TO_POINTER (1));
+ g_hash_table_add (known_uris, known);
} while (gtk_tree_model_iter_next (model, &iter));
}
@@ -340,10 +344,13 @@ vfr_folder_response (EMFolderSelector *selector,
const gchar *uri = uris_iter->data;
gchar *markup;
- if (!uri || g_hash_table_lookup (known_uris, uri))
+ if (uri == NULL)
continue;
- g_hash_table_insert (known_uris, g_strdup (uri), GINT_TO_POINTER (1));
+ if (g_hash_table_contains (known_uris, uri))
+ continue;
+
+ g_hash_table_add (known_uris, g_strdup (uri));
changed = TRUE;
g_queue_push_tail (em_vfolder_rule_get_sources (data->vr), g_strdup (uri));
@@ -425,7 +432,7 @@ source_remove (GtkWidget *widget,
gtk_tree_path_append_index (path, index);
if (gtk_tree_selection_path_is_selected (selection, path)) {
- g_hash_table_insert (to_remove, GINT_TO_POINTER (index), GINT_TO_POINTER (1));
+ g_hash_table_add (to_remove, GINT_TO_POINTER (index));
if (first_selected == -1)
first_selected = index;
@@ -444,7 +451,7 @@ source_remove (GtkWidget *widget,
removed = 0;
prev_source = NULL;
while ((source = em_vfolder_rule_next_source (data->vr, source))) {
- if (g_hash_table_lookup (to_remove, GINT_TO_POINTER (index + removed))) {
+ if (g_hash_table_contains (to_remove, GINT_TO_POINTER (index + removed))) {
path = gtk_tree_path_new ();
gtk_tree_path_append_index (path, index);
gtk_tree_model_get_iter (