mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Merge branch 'master' into readline
This commit is contained in:
commit
93b5ca7a1f
@ -88,11 +88,12 @@ jid_create(const gchar * const str)
|
|||||||
if (slashp != NULL) {
|
if (slashp != NULL) {
|
||||||
result->resourcepart = g_strdup(slashp + 1);
|
result->resourcepart = g_strdup(slashp + 1);
|
||||||
result->domainpart = g_utf8_substring(domain_start, 0, g_utf8_pointer_to_offset(domain_start, slashp));
|
result->domainpart = g_utf8_substring(domain_start, 0, g_utf8_pointer_to_offset(domain_start, slashp));
|
||||||
result->barejid = g_utf8_substring(trimmed, 0, g_utf8_pointer_to_offset(trimmed, slashp));
|
char *barejidraw = g_utf8_substring(trimmed, 0, g_utf8_pointer_to_offset(trimmed, slashp));
|
||||||
|
result->barejid = g_utf8_strdown(barejidraw, -1);
|
||||||
result->fulljid = g_strdup(trimmed);
|
result->fulljid = g_strdup(trimmed);
|
||||||
} else {
|
} else {
|
||||||
result->domainpart = g_strdup(domain_start);
|
result->domainpart = g_strdup(domain_start);
|
||||||
result->barejid = g_strdup(trimmed);
|
result->barejid = g_utf8_strdown(trimmed, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result->domainpart == NULL) {
|
if (result->domainpart == NULL) {
|
||||||
@ -144,7 +145,9 @@ jid_is_valid_room_form(Jid *jid)
|
|||||||
char *
|
char *
|
||||||
create_fulljid(const char * const barejid, const char * const resource)
|
create_fulljid(const char * const barejid, const char * const resource)
|
||||||
{
|
{
|
||||||
|
gchar *barejidlower = g_utf8_strdown(barejid, -1);
|
||||||
GString *full_jid = g_string_new(barejid);
|
GString *full_jid = g_string_new(barejid);
|
||||||
|
g_free(barejidlower);
|
||||||
g_string_append(full_jid, "/");
|
g_string_append(full_jid, "/");
|
||||||
g_string_append(full_jid, resource);
|
g_string_append(full_jid, resource);
|
||||||
|
|
||||||
|
@ -91,7 +91,7 @@ roster_update_presence(const char * const barejid, Resource *resource,
|
|||||||
assert(barejid != NULL);
|
assert(barejid != NULL);
|
||||||
assert(resource != NULL);
|
assert(resource != NULL);
|
||||||
|
|
||||||
PContact contact = g_hash_table_lookup(contacts, barejid);
|
PContact contact = roster_get_contact(barejid);
|
||||||
if (contact == NULL) {
|
if (contact == NULL) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
@ -109,14 +109,18 @@ roster_update_presence(const char * const barejid, Resource *resource,
|
|||||||
PContact
|
PContact
|
||||||
roster_get_contact(const char * const barejid)
|
roster_get_contact(const char * const barejid)
|
||||||
{
|
{
|
||||||
return g_hash_table_lookup(contacts, barejid);
|
gchar *barejidlower = g_utf8_strdown(barejid, -1);
|
||||||
|
PContact contact = g_hash_table_lookup(contacts, barejidlower);
|
||||||
|
g_free(barejidlower);
|
||||||
|
|
||||||
|
return contact;
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
roster_contact_offline(const char * const barejid,
|
roster_contact_offline(const char * const barejid,
|
||||||
const char * const resource, const char * const status)
|
const char * const resource, const char * const status)
|
||||||
{
|
{
|
||||||
PContact contact = g_hash_table_lookup(contacts, barejid);
|
PContact contact = roster_get_contact(barejid);
|
||||||
|
|
||||||
if (contact == NULL) {
|
if (contact == NULL) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -212,7 +216,7 @@ void
|
|||||||
roster_update(const char * const barejid, const char * const name,
|
roster_update(const char * const barejid, const char * const name,
|
||||||
GSList *groups, const char * const subscription, gboolean pending_out)
|
GSList *groups, const char * const subscription, gboolean pending_out)
|
||||||
{
|
{
|
||||||
PContact contact = g_hash_table_lookup(contacts, barejid);
|
PContact contact = roster_get_contact(barejid);
|
||||||
assert(contact != NULL);
|
assert(contact != NULL);
|
||||||
|
|
||||||
p_contact_set_subscription(contact, subscription);
|
p_contact_set_subscription(contact, subscription);
|
||||||
@ -239,7 +243,7 @@ gboolean
|
|||||||
roster_add(const char * const barejid, const char * const name, GSList *groups,
|
roster_add(const char * const barejid, const char * const name, GSList *groups,
|
||||||
const char * const subscription, gboolean pending_out)
|
const char * const subscription, gboolean pending_out)
|
||||||
{
|
{
|
||||||
PContact contact = g_hash_table_lookup(contacts, barejid);
|
PContact contact = roster_get_contact(barejid);
|
||||||
if (contact != NULL) {
|
if (contact != NULL) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -285,6 +285,8 @@ _roster_set_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g_free(barejid_lower);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -324,6 +326,7 @@ _roster_result_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
|||||||
log_warning("Attempt to add contact twice: %s", barejid_lower);
|
log_warning("Attempt to add contact twice: %s", barejid_lower);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g_free(barejid_lower);
|
||||||
item = xmpp_stanza_get_next(item);
|
item = xmpp_stanza_get_next(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user