From b373cbcfc0688c80314b40024a8a9d596bcc9856 Mon Sep 17 00:00:00 2001 From: James Booth Date: Wed, 18 Nov 2015 00:25:35 +0000 Subject: Pass offline filter to roster list functions --- src/roster_list.c | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) (limited to 'src/roster_list.c') diff --git a/src/roster_list.c b/src/roster_list.c index 2f1a0b55..4b2662ad 100644 --- a/src/roster_list.c +++ b/src/roster_list.c @@ -455,7 +455,7 @@ roster_fulljid_autocomplete(const char *const search_str) } GSList* -roster_get_nogroup(roster_ord_t order) +roster_get_nogroup(roster_ord_t order, gboolean include_offline) { GSList *result = NULL; GHashTableIter iter; @@ -471,6 +471,12 @@ roster_get_nogroup(roster_ord_t order) g_hash_table_iter_init(&iter, contacts); while (g_hash_table_iter_next(&iter, &key, &value)) { + PContact contact = value; + const char *presence = p_contact_presence(contact); + if (!include_offline && (g_strcmp0(presence, "offline") == 0)) { + continue; + } + GSList *groups = p_contact_groups(value); if (groups == NULL) { result = g_slist_insert_sorted(result, value, cmp_func); @@ -482,7 +488,7 @@ roster_get_nogroup(roster_ord_t order) } GSList* -roster_get_group(const char *const group, roster_ord_t order) +roster_get_group(const char *const group, roster_ord_t order, gboolean include_offline) { GSList *result = NULL; GHashTableIter iter; @@ -498,6 +504,12 @@ roster_get_group(const char *const group, roster_ord_t order) g_hash_table_iter_init(&iter, contacts); while (g_hash_table_iter_next(&iter, &key, &value)) { + PContact contact = value; + const char *presence = p_contact_presence(contact); + if (!include_offline && (g_strcmp0(presence, "offline") == 0)) { + continue; + } + GSList *groups = p_contact_groups(value); while (groups) { if (strcmp(groups->data, group) == 0) { -- cgit 1.4.1-2-gfad0