[libgdata/libgdata-0-7] contacts: Don't return deleted groups in gdata_contacts_contact_get_groups()
- From: Philip Withnall <pwithnall src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libgdata/libgdata-0-7] contacts: Don't return deleted groups in gdata_contacts_contact_get_groups()
- Date: Thu, 30 Dec 2010 17:12:05 +0000 (UTC)
commit 53cf91cda591c47a5dd767178a1d6acc43103920
Author: Philip Withnall <philip tecnocode co uk>
Date: Tue Dec 21 17:48:50 2010 +0000
contacts: Don't return deleted groups in gdata_contacts_contact_get_groups()
Also take the opportunity to rewrite it to use GHashTableIter instead of
a tiny little callback function.
gdata/services/contacts/gdata-contacts-contact.c | 17 ++++++++++-------
1 files changed, 10 insertions(+), 7 deletions(-)
---
diff --git a/gdata/services/contacts/gdata-contacts-contact.c b/gdata/services/contacts/gdata-contacts-contact.c
index 9b6dcff..1e4a29e 100644
--- a/gdata/services/contacts/gdata-contacts-contact.c
+++ b/gdata/services/contacts/gdata-contacts-contact.c
@@ -2848,12 +2848,6 @@ gdata_contacts_contact_is_group_deleted (GDataContactsContact *self, const gchar
return GPOINTER_TO_UINT (g_hash_table_lookup (self->priv->groups, href));
}
-static void
-get_groups_cb (const gchar *href, gpointer deleted, GList **groups)
-{
- *groups = g_list_prepend (*groups, (gchar*) href);
-}
-
/**
* gdata_contacts_contact_get_groups:
* @self: a #GDataContactsContact
@@ -2867,11 +2861,20 @@ get_groups_cb (const gchar *href, gpointer deleted, GList **groups)
GList *
gdata_contacts_contact_get_groups (GDataContactsContact *self)
{
+ GHashTableIter iter;
+ const gchar *href;
+ gpointer value;
GList *groups = NULL;
g_return_val_if_fail (GDATA_IS_CONTACTS_CONTACT (self), NULL);
- g_hash_table_foreach (self->priv->groups, (GHFunc) get_groups_cb, &groups);
+ g_hash_table_iter_init (&iter, self->priv->groups);
+ while (g_hash_table_iter_next (&iter, (gpointer*) &href, &value) == TRUE) {
+ /* Add the group to the list as long as it hasn't been deleted */
+ if (GPOINTER_TO_UINT (value) == FALSE)
+ groups = g_list_prepend (groups, (gpointer) href);
+ }
+
return g_list_reverse (groups);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]