1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-09-22 19:45:54 -04:00

Added group add and group remove to /roster command

This commit is contained in:
James Booth 2013-06-02 02:48:20 +01:00
parent b450fa3ef7
commit 9dd5456f88
7 changed files with 222 additions and 3 deletions

View File

@ -276,7 +276,7 @@ static struct cmd_t main_commands[] =
NULL } } },
{ "/roster",
_cmd_roster, parse_args_with_freetext, 0, 3,
_cmd_roster, parse_args_with_freetext, 0, 4,
{ "/roster [add|remove|nick] [jid] [handle]", "Manage your roster.",
{ "/roster [add|remove|nick] [jid] [handle]",
"----------------------------------------",
@ -927,6 +927,7 @@ cmd_init(void)
roster_ac = autocomplete_new();
autocomplete_add(roster_ac, strdup("add"));
autocomplete_add(roster_ac, strdup("nick"));
autocomplete_add(roster_ac, strdup("group"));
autocomplete_add(roster_ac, strdup("remove"));
theme_load_ac = NULL;
@ -2091,6 +2092,63 @@ _cmd_roster(gchar **args, struct cmd_help_t help)
return TRUE;
}
// group command
if (strcmp(args[0], "group") == 0) {
char *command = args[1];
char *group = args[2];
char *jid = args[3];
if (command == NULL) {
cons_show("Usage: %s", help.usage);
return TRUE;
}
if (strcmp(command, "show") == 0) {
if (group == NULL) {
cons_show("Usage: %s", help.usage);
return TRUE;
}
GSList *list = roster_get_group(group);
cons_show_roster_group(group, list);
return TRUE;
}
if (strcmp(command, "add") == 0) {
if ((group == NULL) || (jid == NULL)) {
cons_show("Usage: %s", help.usage);
return TRUE;
}
PContact contact = roster_get_contact(jid);
if (contact == NULL) {
cons_show("Contact not found in roster: %s", jid);
return TRUE;
}
roster_add_to_group(group, jid);
return TRUE;
}
if (strcmp(command, "remove") == 0) {
if ((group == NULL) || (jid == NULL)) {
cons_show("Usage: %s", help.usage);
return TRUE;
}
PContact contact = roster_get_contact(jid);
if (contact == NULL) {
cons_show("Contact not found in roster: %s", jid);
return TRUE;
}
roster_remove_from_group(group, jid);
return TRUE;
}
}
cons_show("Usage: %s", help.usage);
return TRUE;
}

View File

@ -101,6 +101,20 @@ p_contact_set_groups(const PContact contact, GSList *groups)
contact->groups = groups;
}
gboolean
p_contact_in_group(const PContact contact, const char * const group)
{
GSList *groups = contact->groups;
while (groups != NULL) {
if (strcmp(groups->data, group) == 0) {
return TRUE;
}
groups = g_slist_next(groups);
}
return FALSE;
}
GSList *
p_contact_groups(const PContact contact)
{

View File

@ -52,5 +52,6 @@ gboolean p_contact_has_available_resource(const PContact contact);
Resource * p_contact_get_resource(const PContact contact, const char * const resource);
void p_contact_set_groups(const PContact contact, GSList *groups);
GSList * p_contact_groups(const PContact contact);
gboolean p_contact_in_group(const PContact contact, const char * const group);
#endif

View File

@ -1240,13 +1240,19 @@ cons_navigation_help(void)
}
void
cons_show_roster(GSList *list)
cons_show_roster_group(const char * const group, GSList *list)
{
GSList *curr = list;
cons_show("");
cons_show("Roster:");
if (curr != NULL) {
cons_show("%s:", group);
} else {
cons_show("No group named %s exists.", group);
}
while(curr) {
PContact contact = curr->data;
GString *title = g_string_new(" ");
title = g_string_append(title, p_contact_barejid(contact));
@ -1268,6 +1274,60 @@ cons_show_roster(GSList *list)
}
cons_show(sub->str);
g_string_free(sub, TRUE);
curr = g_slist_next(curr);
}
ui_console_dirty();
cons_alert();
}
void
cons_show_roster(GSList *list)
{
GSList *curr = list;
cons_show("");
cons_show("Roster:");
while(curr) {
PContact contact = curr->data;
GString *title = g_string_new(" ");
title = g_string_append(title, p_contact_barejid(contact));
if (p_contact_name(contact) != NULL) {
title = g_string_append(title, " (");
title = g_string_append(title, strdup(p_contact_name(contact)));
title = g_string_append(title, ")");
}
cons_show(title->str);
g_string_free(title, TRUE);
GString *sub = g_string_new(" Subscription : ");
sub = g_string_append(sub, p_contact_subscription(contact));
if (p_contact_pending_out(contact)) {
sub = g_string_append(sub, ", request sent");
}
if (presence_sub_request_exists(p_contact_barejid(contact))) {
sub = g_string_append(sub, ", request received");
}
cons_show(sub->str);
g_string_free(sub, TRUE);
GSList *groups = p_contact_groups(contact);
if (groups != NULL) {
GString *groups_str = g_string_new(" Groups : ");
while (groups != NULL) {
g_string_append(groups_str, strdup(groups->data));
if (g_slist_next(groups) != NULL) {
g_string_append(groups_str, ", ");
}
groups = g_slist_next(groups);
}
cons_show(groups_str->str);
g_string_free(groups_str, TRUE);
}
curr = g_slist_next(curr);
}

View File

@ -168,6 +168,7 @@ void cons_show_error(const char * const cmd, ...);
void cons_highlight_show(const char * const cmd);
void cons_show_contacts(GSList * list);
void cons_show_roster(GSList * list);
void cons_show_roster_group(const char * const group, GSList * list);
void cons_show_wins(void);
void cons_show_status(const char * const barejid);
void cons_show_info(PContact pcontact);

View File

@ -286,6 +286,63 @@ roster_change_name(const char * const barejid, const char * const new_name)
}
}
void
roster_add_to_group(const char * const group, const char * const barejid)
{
PContact contact = g_hash_table_lookup(contacts, barejid);
if (contact != NULL) {
if (p_contact_in_group(contact, group)) {
return;
}
GSList *groups = p_contact_groups(contact);
GSList *new_groups = NULL;
while (groups != NULL) {
new_groups = g_slist_append(new_groups, strdup(groups->data));
groups = g_slist_next(groups);
}
new_groups = g_slist_append(new_groups, strdup(group));
xmpp_conn_t * const conn = connection_get_conn();
xmpp_ctx_t * const ctx = connection_get_ctx();
xmpp_stanza_t *iq = stanza_create_roster_set(ctx, barejid,
p_contact_name(contact), new_groups);
xmpp_send(conn, iq);
xmpp_stanza_release(iq);
}
}
void
roster_remove_from_group(const char * const group, const char * const barejid)
{
PContact contact = g_hash_table_lookup(contacts, barejid);
if (contact != NULL) {
if (!p_contact_in_group(contact, group)) {
return;
}
GSList *groups = p_contact_groups(contact);
GSList *new_groups = NULL;
while (groups != NULL) {
if (strcmp(groups->data, group) != 0) {
new_groups = g_slist_append(new_groups, strdup(groups->data));
}
groups = g_slist_next(groups);
}
xmpp_conn_t * const conn = connection_get_conn();
xmpp_ctx_t * const ctx = connection_get_ctx();
xmpp_stanza_t *iq = stanza_create_roster_set(ctx, barejid,
p_contact_name(contact), new_groups);
xmpp_send(conn, iq);
xmpp_stanza_release(iq);
}
}
gboolean
roster_has_pending_subscriptions(void)
{
@ -321,6 +378,30 @@ roster_get_contacts(void)
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 != NULL) {
if (strcmp(groups->data, group) == 0) {
result = g_slist_insert_sorted(result, value, (GCompareFunc)_compare_contacts);
break;
}
groups = g_slist_next(groups);
}
}
// resturn all contact structs
return result;
}
char *
roster_find_contact(char *search_str)
{

View File

@ -146,5 +146,9 @@ void roster_change_name(const char * const barejid, const char * const new_name)
char * roster_barejid_from_name(const char * const name);
void roster_add_new(const char * const barejid, const char * const name);
void roster_remove(const char * const barejid);
GSList * roster_get_group(const char * const group);
void roster_add_to_group(const char * const group, const char * const barejid);
void roster_remove_from_group(const char * const group,
const char * const barejid);
#endif