mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
chatwin: fix memory leak when load history
_chatwin_history() reassigns msg->plain without freeing previous string. This leads to memory leak. As a temporary solution, free replaced string. Fixes #1585.
This commit is contained in:
parent
8be49e9e21
commit
2e0adbd004
@ -519,7 +519,11 @@ _chatwin_history(ProfChatWin* chatwin, const char* const contact_barejid)
|
|||||||
|
|
||||||
while (curr) {
|
while (curr) {
|
||||||
ProfMessage* msg = curr->data;
|
ProfMessage* msg = curr->data;
|
||||||
|
char *msg_plain = msg->plain;
|
||||||
msg->plain = plugins_pre_chat_message_display(msg->from_jid->barejid, msg->from_jid->resourcepart, msg->plain);
|
msg->plain = plugins_pre_chat_message_display(msg->from_jid->barejid, msg->from_jid->resourcepart, msg->plain);
|
||||||
|
// This is dirty workaround for memory leak. We reassign msg->plain above so have to free previous object
|
||||||
|
// TODO: Make a better solution, for example, pass msg object to the function and it will replace msg->plain properly if needed.
|
||||||
|
free(msg_plain);
|
||||||
win_print_history((ProfWin*)chatwin, msg);
|
win_print_history((ProfWin*)chatwin, msg);
|
||||||
curr = g_slist_next(curr);
|
curr = g_slist_next(curr);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user