]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Remove a memory leak from updating realtime queues
authorMark Michelson <mmichelson@digium.com>
Tue, 29 Jan 2008 23:02:03 +0000 (23:02 +0000)
committerMark Michelson <mmichelson@digium.com>
Tue, 29 Jan 2008 23:02:03 +0000 (23:02 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@101035 65c4cc65-6c06-0410-ace0-fbb531ad65f3

apps/app_queue.c

index 761d2fc0795e534bbba56709ba5a168c300b6b14..0ee13c91b64d4aad4a88d07bdb89be1193bfb867 100644 (file)
@@ -1285,8 +1285,7 @@ static void update_realtime_members(struct call_queue *q)
        char *interface = NULL;
        struct ao2_iterator mem_iter;
 
-       member_config = ast_load_realtime_multientry("queue_members", "interface LIKE", "%", "queue_name", q->name , NULL);
-       if (!member_config) {
+       if (!(member_config = ast_load_realtime_multientry("queue_members", "interface LIKE", "%", "queue_name", q->name , NULL))) {
                /*This queue doesn't have realtime members*/
                if (option_debug > 2)
                        ast_log(LOG_DEBUG, "Queue %s has no realtime members defined. No need for update\n", q->name);
@@ -1323,6 +1322,7 @@ static void update_realtime_members(struct call_queue *q)
                ao2_ref(m, -1);
        }
        ast_mutex_unlock(&q->lock);
+       ast_config_destroy(member_config);
 }
 
 static struct call_queue *load_realtime_queue(const char *queuename)