summaryrefslogtreecommitdiff
path: root/apps/app_queue.c
diff options
context:
space:
mode:
authorRussell Bryant <russell@russellbryant.com>2005-12-01 01:17:41 +0000
committerRussell Bryant <russell@russellbryant.com>2005-12-01 01:17:41 +0000
commitad122bf6cdb8b74dfd2babda5df6fc454e121262 (patch)
treebeb0fcf2396ddcd3b61cf52627071ae51a6cc06c /apps/app_queue.c
parentb994fcae8baa87d1f13ad69d5143ffd41e0e7758 (diff)
fix queue weight feature - compare member interfaces instead of pointers to
the members, since each queue has its own list of members. (issue #5863) git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@7248 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'apps/app_queue.c')
-rw-r--r--apps/app_queue.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/apps/app_queue.c b/apps/app_queue.c
index ef8a1b2b7..7f28a6ece 100644
--- a/apps/app_queue.c
+++ b/apps/app_queue.c
@@ -1304,7 +1304,7 @@ static int compare_weight(struct ast_call_queue *rq, struct member *member)
ast_mutex_lock(&q->lock);
if (q->count && q->members) {
for (mem = q->members; mem; mem = mem->next) {
- if (mem == member) {
+ if (!strcmp(mem->interface, member->interface)) {
ast_log(LOG_DEBUG, "Found matching member %s in queue '%s'\n", mem->interface, q->name);
if (q->weight > rq->weight) {
ast_log(LOG_DEBUG, "Queue '%s' (weight %d, calls %d) is preferred over '%s' (weight %d, calls %d)\n", q->name, q->weight, q->count, rq->name, rq->weight, rq->count);