diff options
author | Dmitry Podgorny <pasis.ua@gmail.com> | 2019-10-14 00:19:08 +0300 |
---|---|---|
committer | Dmitry Podgorny <pasis.ua@gmail.com> | 2019-10-14 00:19:08 +0300 |
commit | 6d11cd2db3bd22b9ddac0b4a59c610939100694e (patch) | |
tree | 2a0ef8556810691d9aa9af5fe50f7972000f809a | |
parent | ffd74229faae6842f0e8bd50d894333d3de86d98 (diff) | |
download | profani-tty-6d11cd2db3bd22b9ddac0b4a59c610939100694e.tar.gz |
Fix memory leak in cmd_join()
room is either argv[0] or allocated by GString. We have to free memory in the 2nd case. Replace argv[0] with g_strdup(argv[0]) in order to make unconditional g_free().
-rw-r--r-- | src/command/cmd_funcs.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/src/command/cmd_funcs.c b/src/command/cmd_funcs.c index 2c68cd1f..9b2622e7 100644 --- a/src/command/cmd_funcs.c +++ b/src/command/cmd_funcs.c @@ -3606,7 +3606,7 @@ cmd_join(ProfWin *window, const char *const command, gchar **args) // full room jid supplied (room@server) if (room_arg->localpart) { - room = args[0]; + room = g_strdup(args[0]); // server not supplied (room), use account preference } else if (account->muc_service) { @@ -3631,6 +3631,7 @@ cmd_join(ProfWin *window, const char *const command, gchar **args) if (!parsed) { cons_bad_cmd_usage(command); cons_show(""); + g_free(room); jid_destroy(room_arg); return TRUE; } @@ -3657,6 +3658,7 @@ cmd_join(ProfWin *window, const char *const command, gchar **args) ui_switch_to_room(room); } + g_free(room); jid_destroy(room_arg); account_free(account); |