diff options
author | Martin Pycko <martinp@digium.com> | 2003-12-22 16:35:48 +0000 |
---|---|---|
committer | Martin Pycko <martinp@digium.com> | 2003-12-22 16:35:48 +0000 |
commit | f1676593d0dd2e77858f140f78218fb2fdb6f983 (patch) | |
tree | 4c9900817e7d3a7576bd5027309c075fcf4a895f /apps/app_voicemail.c | |
parent | ddf7bc57d3cf6c604995b93d790236e2e10ae470 (diff) |
Don't free the user structure before reading the next pointer
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1874 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'apps/app_voicemail.c')
-rwxr-xr-x | apps/app_voicemail.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/apps/app_voicemail.c b/apps/app_voicemail.c index ced94c639..68b815467 100755 --- a/apps/app_voicemail.c +++ b/apps/app_voicemail.c @@ -2166,7 +2166,7 @@ static int forward_message(struct ast_channel *chan, char *context, char *dir, i char fn[256]; char callerid[512]; int res = 0, cmd = 0; - struct ast_vm_user *receiver, *extensions = NULL, *vmtmp = NULL; + struct ast_vm_user *receiver, *extensions = NULL, *vmtmp = NULL, *vmfree; char tmp[256]; char *stringp, *s; int saved_messages = 0, found = 0; @@ -2270,9 +2270,10 @@ static int forward_message(struct ast_channel *chan, char *context, char *dir, i /* Leave voicemail for someone */ manager_event(EVENT_FLAG_CALL, "MessageWaiting", "Mailbox: %s\r\nWaiting: %d\r\n", vmtmp->mailbox, ast_app_has_voicemail(vmtmp->mailbox)); - free_user(vmtmp); saved_messages++; + vmfree = vmtmp; vmtmp = vmtmp->next; + free_user(vmfree); } if (saved_messages > 0) { /* give confirmatopm that the message was saved */ |