1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-11-03 19:37:16 -05:00

Pass ordering to roster list functions

This commit is contained in:
James Booth 2015-11-18 00:06:00 +00:00
parent 8e8852fa9f
commit 2260e3bd6f
7 changed files with 54 additions and 92 deletions

View File

@ -1320,13 +1320,13 @@ _who_roster(ProfWin *window, const char *const command, gchar **args)
cons_show(""); cons_show("");
GSList *list = NULL; GSList *list = NULL;
if (group) { if (group) {
list = roster_get_group(group); list = roster_get_group(group, ROSTER_ORD_NAME);
if (list == NULL) { if (list == NULL) {
cons_show("No such group: %s.", group); cons_show("No such group: %s.", group);
return; return;
} }
} else { } else {
list = roster_get_contacts(); list = roster_get_contacts(ROSTER_ORD_NAME);
if (list == NULL) { if (list == NULL) {
cons_show("No contacts in roster."); cons_show("No contacts in roster.");
return; return;
@ -1628,7 +1628,7 @@ cmd_group(ProfWin *window, const char *const command, gchar **args)
return TRUE; return TRUE;
} }
GSList *list = roster_get_group(group); GSList *list = roster_get_group(group, ROSTER_ORD_NAME);
cons_show_roster_group(group, list); cons_show_roster_group(group, list);
return TRUE; return TRUE;
} }
@ -1711,7 +1711,7 @@ cmd_roster(ProfWin *window, const char *const command, gchar **args)
return TRUE; return TRUE;
} }
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
cons_show_roster(list); cons_show_roster(list);
g_slist_free(list); g_slist_free(list);
return TRUE; return TRUE;
@ -1931,7 +1931,7 @@ cmd_roster(ProfWin *window, const char *const command, gchar **args)
return TRUE; return TRUE;
} }
GSList *all = roster_get_contacts(); GSList *all = roster_get_contacts(ROSTER_ORD_NAME);
GSList *curr = all; GSList *curr = all;
while (curr) { while (curr) {
PContact contact = curr->data; PContact contact = curr->data;

View File

@ -383,33 +383,23 @@ roster_get_contacts_by_presence(const char *const presence)
} }
GSList* GSList*
roster_get_contacts_ord_presence(void) roster_get_contacts(roster_ord_t order)
{ {
GSList *result = NULL; GSList *result = NULL;
GHashTableIter iter; GHashTableIter iter;
gpointer key; gpointer key;
gpointer value; gpointer value;
g_hash_table_iter_init(&iter, contacts); GCompareFunc cmp_func;
while (g_hash_table_iter_next(&iter, &key, &value)) { if (order == ROSTER_ORD_PRESENCE) {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_presence); cmp_func = (GCompareFunc) _compare_presence;
} else {
cmp_func = (GCompareFunc) _compare_name;
} }
// return all contact structs
return result;
}
GSList*
roster_get_contacts(void)
{
GSList *result = NULL;
GHashTableIter iter;
gpointer key;
gpointer value;
g_hash_table_iter_init(&iter, contacts); g_hash_table_iter_init(&iter, contacts);
while (g_hash_table_iter_next(&iter, &key, &value)) { while (g_hash_table_iter_next(&iter, &key, &value)) {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_name); result = g_slist_insert_sorted(result, value, cmp_func);
} }
// return all contact structs // return all contact structs
@ -465,18 +455,25 @@ roster_fulljid_autocomplete(const char *const search_str)
} }
GSList* GSList*
roster_get_nogroup_ord_presence(void) roster_get_nogroup(roster_ord_t order)
{ {
GSList *result = NULL; GSList *result = NULL;
GHashTableIter iter; GHashTableIter iter;
gpointer key; gpointer key;
gpointer value; gpointer value;
GCompareFunc cmp_func;
if (order == ROSTER_ORD_PRESENCE) {
cmp_func = (GCompareFunc) _compare_presence;
} else {
cmp_func = (GCompareFunc) _compare_name;
}
g_hash_table_iter_init(&iter, contacts); g_hash_table_iter_init(&iter, contacts);
while (g_hash_table_iter_next(&iter, &key, &value)) { while (g_hash_table_iter_next(&iter, &key, &value)) {
GSList *groups = p_contact_groups(value); GSList *groups = p_contact_groups(value);
if (groups == NULL) { if (groups == NULL) {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_presence); result = g_slist_insert_sorted(result, value, cmp_func);
} }
} }
@ -485,63 +482,26 @@ roster_get_nogroup_ord_presence(void)
} }
GSList* GSList*
roster_get_nogroup(void) roster_get_group(const char *const group, roster_ord_t order)
{ {
GSList *result = NULL; GSList *result = NULL;
GHashTableIter iter; GHashTableIter iter;
gpointer key; gpointer key;
gpointer value; gpointer value;
g_hash_table_iter_init(&iter, contacts); GCompareFunc cmp_func;
while (g_hash_table_iter_next(&iter, &key, &value)) { if (order == ROSTER_ORD_PRESENCE) {
GSList *groups = p_contact_groups(value); cmp_func = (GCompareFunc) _compare_presence;
if (groups == NULL) { } else {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_name); cmp_func = (GCompareFunc) _compare_name;
}
} }
// return all contact structs
return result;
}
GSList*
roster_get_group_ord_presence(const char *const group)
{
GSList *result = NULL;
GHashTableIter iter;
gpointer key;
gpointer value;
g_hash_table_iter_init(&iter, contacts); g_hash_table_iter_init(&iter, contacts);
while (g_hash_table_iter_next(&iter, &key, &value)) { while (g_hash_table_iter_next(&iter, &key, &value)) {
GSList *groups = p_contact_groups(value); GSList *groups = p_contact_groups(value);
while (groups) { while (groups) {
if (strcmp(groups->data, group) == 0) { if (strcmp(groups->data, group) == 0) {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_presence); result = g_slist_insert_sorted(result, value, cmp_func);
break;
}
groups = g_slist_next(groups);
}
}
// return all contact structs
return result;
}
GSList*
roster_get_group(const char *const group)
{
GSList *result = NULL;
GHashTableIter iter;
gpointer key;
gpointer value;
g_hash_table_iter_init(&iter, contacts);
while (g_hash_table_iter_next(&iter, &key, &value)) {
GSList *groups = p_contact_groups(value);
while (groups) {
if (strcmp(groups->data, group) == 0) {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_name);
break; break;
} }
groups = g_slist_next(groups); groups = g_slist_next(groups);

View File

@ -40,6 +40,11 @@
#include "resource.h" #include "resource.h"
#include "contact.h" #include "contact.h"
typedef enum {
ROSTER_ORD_NAME,
ROSTER_ORD_PRESENCE
} roster_ord_t;
void roster_clear(void); void roster_clear(void);
gboolean roster_update_presence(const char *const barejid, Resource *resource, GDateTime *last_activity); gboolean roster_update_presence(const char *const barejid, Resource *resource, GDateTime *last_activity);
PContact roster_get_contact(const char *const barejid); PContact roster_get_contact(const char *const barejid);
@ -54,20 +59,17 @@ void roster_update(const char *const barejid, const char *const name, GSList *gr
gboolean roster_add(const char *const barejid, const char *const name, GSList *groups, const char *const subscription, gboolean roster_add(const char *const barejid, const char *const name, GSList *groups, const char *const subscription,
gboolean pending_out); gboolean pending_out);
char* roster_barejid_from_name(const char *const name); char* roster_barejid_from_name(const char *const name);
GSList* roster_get_contacts(void); GSList* roster_get_contacts(roster_ord_t order);
GSList* roster_get_contacts_ord_presence(void);
GSList* roster_get_contacts_online(void); GSList* roster_get_contacts_online(void);
gboolean roster_has_pending_subscriptions(void); gboolean roster_has_pending_subscriptions(void);
char* roster_contact_autocomplete(const char *const search_str); char* roster_contact_autocomplete(const char *const search_str);
char* roster_fulljid_autocomplete(const char *const search_str); char* roster_fulljid_autocomplete(const char *const search_str);
GSList* roster_get_group(const char *const group); GSList* roster_get_group(const char *const group, roster_ord_t order);
GSList* roster_get_group_ord_presence(const char *const group);
GSList* roster_get_groups(void); GSList* roster_get_groups(void);
char* roster_group_autocomplete(const char *const search_str); char* roster_group_autocomplete(const char *const search_str);
char* roster_barejid_autocomplete(const char *const search_str); char* roster_barejid_autocomplete(const char *const search_str);
GSList* roster_get_contacts_by_presence(const char *const presence); GSList* roster_get_contacts_by_presence(const char *const presence);
GSList* roster_get_nogroup(void); GSList* roster_get_nogroup(roster_ord_t order);
GSList* roster_get_nogroup_ord_presence(void);
char* roster_get_msg_display_name(const char *const barejid, const char *const resource); char* roster_get_msg_display_name(const char *const barejid, const char *const resource);
#endif #endif

View File

@ -527,7 +527,7 @@ void
cons_show_sent_subs(void) cons_show_sent_subs(void)
{ {
if (roster_has_pending_subscriptions()) { if (roster_has_pending_subscriptions()) {
GSList *contacts = roster_get_contacts(); GSList *contacts = roster_get_contacts(ROSTER_ORD_NAME);
PContact contact = NULL; PContact contact = NULL;
cons_show("Awaiting subscription responses from:"); cons_show("Awaiting subscription responses from:");
GSList *curr = contacts; GSList *curr = contacts;

View File

@ -171,9 +171,9 @@ _rosterwin_contacts_by_group(ProfLayoutSplit *layout, char *group)
char *order = prefs_get_string(PREF_ROSTER_ORDER); char *order = prefs_get_string(PREF_ROSTER_ORDER);
if (g_strcmp0(order, "presence") == 0) { if (g_strcmp0(order, "presence") == 0) {
contacts = roster_get_group_ord_presence(group); contacts = roster_get_group(group, ROSTER_ORD_PRESENCE);
} else { } else {
contacts = roster_get_group(group); contacts = roster_get_group(group, ROSTER_ORD_NAME);
} }
if (contacts) { if (contacts) {
@ -194,9 +194,9 @@ _rosterwin_contacts_by_no_group(ProfLayoutSplit *layout)
char *order = prefs_get_string(PREF_ROSTER_ORDER); char *order = prefs_get_string(PREF_ROSTER_ORDER);
if (g_strcmp0(order, "presence") == 0) { if (g_strcmp0(order, "presence") == 0) {
contacts = roster_get_nogroup_ord_presence(); contacts = roster_get_nogroup(ROSTER_ORD_PRESENCE);
} else { } else {
contacts = roster_get_nogroup(); contacts = roster_get_nogroup(ROSTER_ORD_NAME);
} }
if (contacts) { if (contacts) {
@ -248,9 +248,9 @@ rosterwin_roster(void)
char *order = prefs_get_string(PREF_ROSTER_ORDER); char *order = prefs_get_string(PREF_ROSTER_ORDER);
if (g_strcmp0(order, "presence") == 0) { if (g_strcmp0(order, "presence") == 0) {
contacts = roster_get_contacts_ord_presence(); contacts = roster_get_contacts(ROSTER_ORD_PRESENCE);
} else { } else {
contacts = roster_get_contacts(); contacts = roster_get_contacts(ROSTER_ORD_NAME);
} }
if (contacts) { if (contacts) {

View File

@ -55,7 +55,7 @@ void cmd_roster_shows_roster_when_no_args(void **state)
roster_init(); roster_init();
roster_add("bob@server.org", "bob", NULL, "both", FALSE); roster_add("bob@server.org", "bob", NULL, "both", FALSE);
GSList *roster = roster_get_contacts(); GSList *roster = roster_get_contacts(ROSTER_ORD_NAME);
expect_memory(cons_show_roster, list, roster, sizeof(roster)); expect_memory(cons_show_roster, list, roster, sizeof(roster));

View File

@ -12,7 +12,7 @@
void empty_list_when_none_added(void **state) void empty_list_when_none_added(void **state)
{ {
roster_init(); roster_init();
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
assert_null(list); assert_null(list);
roster_clear(); roster_clear();
roster_free(); roster_free();
@ -22,7 +22,7 @@ void contains_one_element(void **state)
{ {
roster_init(); roster_init();
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
assert_int_equal(1, g_slist_length(list)); assert_int_equal(1, g_slist_length(list));
roster_clear(); roster_clear();
roster_free(); roster_free();
@ -32,7 +32,7 @@ void first_element_correct(void **state)
{ {
roster_init(); roster_init();
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
PContact james = list->data; PContact james = list->data;
assert_string_equal("James", p_contact_barejid(james)); assert_string_equal("James", p_contact_barejid(james));
@ -45,7 +45,7 @@ void contains_two_elements(void **state)
roster_init(); roster_init();
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
assert_int_equal(2, g_slist_length(list)); assert_int_equal(2, g_slist_length(list));
roster_clear(); roster_clear();
@ -57,7 +57,7 @@ void first_and_second_elements_correct(void **state)
roster_init(); roster_init();
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
PContact first = list->data; PContact first = list->data;
PContact second = (g_slist_next(list))->data; PContact second = (g_slist_next(list))->data;
@ -74,7 +74,7 @@ void contains_three_elements(void **state)
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
roster_add("Bob", NULL, NULL, NULL, FALSE); roster_add("Bob", NULL, NULL, NULL, FALSE);
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
assert_int_equal(3, g_slist_length(list)); assert_int_equal(3, g_slist_length(list));
roster_clear(); roster_clear();
@ -87,7 +87,7 @@ void first_three_elements_correct(void **state)
roster_add("Bob", NULL, NULL, NULL, FALSE); roster_add("Bob", NULL, NULL, NULL, FALSE);
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
PContact bob = list->data; PContact bob = list->data;
PContact dave = (g_slist_next(list))->data; PContact dave = (g_slist_next(list))->data;
PContact james = (g_slist_next(g_slist_next(list)))->data; PContact james = (g_slist_next(g_slist_next(list)))->data;
@ -106,7 +106,7 @@ void add_twice_at_beginning_adds_once(void **state)
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
roster_add("Bob", NULL, NULL, NULL, FALSE); roster_add("Bob", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
PContact first = list->data; PContact first = list->data;
PContact second = (g_slist_next(list))->data; PContact second = (g_slist_next(list))->data;
PContact third = (g_slist_next(g_slist_next(list)))->data; PContact third = (g_slist_next(g_slist_next(list)))->data;
@ -126,7 +126,7 @@ void add_twice_in_middle_adds_once(void **state)
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
roster_add("Bob", NULL, NULL, NULL, FALSE); roster_add("Bob", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
PContact first = list->data; PContact first = list->data;
PContact second = (g_slist_next(list))->data; PContact second = (g_slist_next(list))->data;
PContact third = (g_slist_next(g_slist_next(list)))->data; PContact third = (g_slist_next(g_slist_next(list)))->data;
@ -146,7 +146,7 @@ void add_twice_at_end_adds_once(void **state)
roster_add("Dave", NULL, NULL, NULL, FALSE); roster_add("Dave", NULL, NULL, NULL, FALSE);
roster_add("Bob", NULL, NULL, NULL, FALSE); roster_add("Bob", NULL, NULL, NULL, FALSE);
roster_add("James", NULL, NULL, NULL, FALSE); roster_add("James", NULL, NULL, NULL, FALSE);
GSList *list = roster_get_contacts(); GSList *list = roster_get_contacts(ROSTER_ORD_NAME);
PContact first = list->data; PContact first = list->data;
PContact second = (g_slist_next(list))->data; PContact second = (g_slist_next(list))->data;
PContact third = (g_slist_next(g_slist_next(list)))->data; PContact third = (g_slist_next(g_slist_next(list)))->data;