1
0
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Merge pull request #1416 from profanity-im/memleaks2

Fix memory leak in _handle_chat()
This commit is contained in:
Michael Vetter 2020-08-10 14:43:57 +02:00 committed by GitHub
commit 02cf186476
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1239,17 +1239,10 @@ _handle_chat(xmpp_stanza_t* const stanza, gboolean is_mam, gboolean is_carbon, c
} }
Jid* jid = jid_create(from); Jid* jid = jid_create(from);
Jid* to_jid = NULL;
const gchar* to = xmpp_stanza_get_to(stanza);
if (to) {
to_jid = jid_create(to);
}
// private message from chat room use full jid (room/nick) // private message from chat room use full jid (room/nick)
if (muc_active(jid->barejid)) { if (muc_active(jid->barejid)) {
_handle_muc_private_message(stanza); _handle_muc_private_message(stanza);
jid_destroy(jid); jid_destroy(jid);
jid_destroy(to_jid);
return; return;
} }
@ -1257,15 +1250,13 @@ _handle_chat(xmpp_stanza_t* const stanza, gboolean is_mam, gboolean is_carbon, c
ProfMessage* message = message_init(); ProfMessage* message = message_init();
message->is_mam = is_mam; message->is_mam = is_mam;
message->from_jid = jid; message->from_jid = jid;
if (to_jid) { const gchar* to = xmpp_stanza_get_to(stanza);
message->to_jid = to_jid; if (to) {
} else { message->to_jid = jid_create(to);
if (is_carbon) { } else if (is_carbon) {
// happens when receive a carbon of a self sent message // happens when receive a carbon of a self sent message
// really? maybe some servers do this, but it's not required. // really? maybe some servers do this, but it's not required.
Jid* from_jid = jid_create(from); message->to_jid = jid_create(from);
message->to_jid = from_jid;
}
} }
if (mucuser) { if (mucuser) {
@ -1274,11 +1265,6 @@ _handle_chat(xmpp_stanza_t* const stanza, gboolean is_mam, gboolean is_carbon, c
message->type = PROF_MSG_TYPE_CHAT; message->type = PROF_MSG_TYPE_CHAT;
} }
const gchar* to_text = xmpp_stanza_get_to(stanza);
if (to_text) {
message->to_jid = jid_create(to_text);
}
// message stanza id // message stanza id
const char* id = xmpp_stanza_get_id(stanza); const char* id = xmpp_stanza_get_id(stanza);
if (id) { if (id) {