mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Use autocomplete instead of hash table for subscription requests
This commit is contained in:
parent
ae4c54bdcc
commit
53eeb0ef45
@ -571,16 +571,17 @@ cons_show_software_version(const char * const jid, const char * const presence,
|
||||
void
|
||||
cons_show_received_subs(void)
|
||||
{
|
||||
GList *received = presence_get_subscription_requests();
|
||||
GSList *received = presence_get_subscription_requests();
|
||||
if (received == NULL) {
|
||||
cons_show("No outstanding subscription requests.");
|
||||
} else {
|
||||
cons_show("Outstanding subscription requests from:",
|
||||
g_list_length(received));
|
||||
g_slist_length(received));
|
||||
while (received != NULL) {
|
||||
cons_show(" %s", received->data);
|
||||
received = g_list_next(received);
|
||||
received = g_slist_next(received);
|
||||
}
|
||||
g_slist_free_full(received, g_free);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -37,7 +37,7 @@
|
||||
#include "xmpp/stanza.h"
|
||||
#include "xmpp/xmpp.h"
|
||||
|
||||
static GHashTable *sub_requests;
|
||||
static Autocomplete sub_requests_ac;
|
||||
|
||||
#define HANDLE(ns, type, func) xmpp_handler_add(conn, func, ns, \
|
||||
STANZA_NAME_PRESENCE, type, ctx)
|
||||
@ -63,8 +63,7 @@ void _send_caps_request(char *node, char *caps_key, char *id, char *from);
|
||||
void
|
||||
presence_init(void)
|
||||
{
|
||||
sub_requests =
|
||||
g_hash_table_new_full(g_str_hash, g_str_equal, g_free, g_free);
|
||||
sub_requests_ac = autocomplete_new();
|
||||
}
|
||||
|
||||
void
|
||||
@ -92,7 +91,8 @@ presence_subscription(const char * const jid, const jabber_subscr_t action)
|
||||
const char *type = NULL;
|
||||
|
||||
Jid *jidp = jid_create(jid);
|
||||
g_hash_table_remove(sub_requests, jidp->barejid);
|
||||
|
||||
autocomplete_remove(sub_requests_ac, jidp->barejid);
|
||||
|
||||
switch (action)
|
||||
{
|
||||
@ -123,28 +123,22 @@ presence_subscription(const char * const jid, const jabber_subscr_t action)
|
||||
jid_destroy(jidp);
|
||||
}
|
||||
|
||||
GList *
|
||||
GSList *
|
||||
presence_get_subscription_requests(void)
|
||||
{
|
||||
return g_hash_table_get_keys(sub_requests);
|
||||
return autocomplete_get_list(sub_requests_ac);
|
||||
}
|
||||
|
||||
gint
|
||||
presence_sub_request_count(void)
|
||||
{
|
||||
if (sub_requests == NULL) {
|
||||
return 0;
|
||||
} else {
|
||||
return g_hash_table_size(sub_requests);
|
||||
}
|
||||
return autocomplete_length(sub_requests_ac);
|
||||
}
|
||||
|
||||
void
|
||||
presence_free_sub_requests(void)
|
||||
{
|
||||
if (sub_requests != NULL) {
|
||||
g_hash_table_remove_all(sub_requests);
|
||||
}
|
||||
autocomplete_free(sub_requests_ac);
|
||||
}
|
||||
|
||||
void
|
||||
@ -293,7 +287,7 @@ _unsubscribed_handler(xmpp_conn_t * const conn,
|
||||
log_debug("Unsubscribed presence handler fired for %s", from);
|
||||
|
||||
prof_handle_subscription(from_jid->barejid, PRESENCE_UNSUBSCRIBED);
|
||||
g_hash_table_remove(sub_requests, from_jid->barejid);
|
||||
autocomplete_remove(sub_requests_ac, from_jid->barejid);
|
||||
|
||||
jid_destroy(from_jid);
|
||||
|
||||
@ -309,7 +303,7 @@ _subscribed_handler(xmpp_conn_t * const conn,
|
||||
log_debug("Subscribed presence handler fired for %s", from);
|
||||
|
||||
prof_handle_subscription(from_jid->barejid, PRESENCE_SUBSCRIBED);
|
||||
g_hash_table_remove(sub_requests, from_jid->barejid);
|
||||
autocomplete_remove(sub_requests_ac, from_jid->barejid);
|
||||
|
||||
jid_destroy(from_jid);
|
||||
|
||||
@ -325,8 +319,7 @@ _subscribe_handler(xmpp_conn_t * const conn,
|
||||
log_debug("Subscribe presence handler fired for %s", from);
|
||||
|
||||
prof_handle_subscription(from_jid->barejid, PRESENCE_SUBSCRIBE);
|
||||
g_hash_table_insert(sub_requests, strdup(from_jid->barejid),
|
||||
strdup(from_jid->barejid));
|
||||
autocomplete_add(sub_requests_ac, strdup(from_jid->barejid));
|
||||
|
||||
jid_destroy(from_jid);
|
||||
|
||||
|
@ -103,7 +103,7 @@ void message_send_duck(const char * const query);
|
||||
|
||||
// presence functions
|
||||
void presence_subscription(const char * const jid, const jabber_subscr_t action);
|
||||
GList* presence_get_subscription_requests(void);
|
||||
GSList* presence_get_subscription_requests(void);
|
||||
gint presence_sub_request_count(void);
|
||||
void presence_join_room(Jid *jid);
|
||||
void presence_change_room_nick(const char * const room, const char * const nick);
|
||||
|
Loading…
Reference in New Issue
Block a user