[svn-commits] mmichelson: branch mmichelson/queue-reset r101125 - /team/mmichelson/queue-re...

SVN commits to the Digium repositories svn-commits at lists.digium.com
Tue Jan 29 18:42:38 CST 2008


Author: mmichelson
Date: Tue Jan 29 18:42:37 2008
New Revision: 101125

URL: http://svn.digium.com/view/asterisk?view=rev&rev=101125
Log:
Two changes:

1. Move membercount changes to the member reloading area and out of queue initialization since
   it should only be affected if reloading members.
2. Remove my quick reload of a single queue since the logic was off. 


Modified:
    team/mmichelson/queue-reset/apps/app_queue.c

Modified: team/mmichelson/queue-reset/apps/app_queue.c
URL: http://svn.digium.com/view/asterisk/team/mmichelson/queue-reset/apps/app_queue.c?view=diff&rev=101125&r1=101124&r2=101125
==============================================================================
--- team/mmichelson/queue-reset/apps/app_queue.c (original)
+++ team/mmichelson/queue-reset/apps/app_queue.c Tue Jan 29 18:42:37 2008
@@ -922,7 +922,6 @@
 		else
 			q->members = ao2_container_alloc(37, member_hash_fn, member_cmp_fn);
 	}
-	q->membercount = 0;
 	q->found = 1;
 
 	ast_string_field_set(q, sound_next, "queue-youarenext");
@@ -1433,6 +1432,7 @@
 		ao2_lock(q);
 		clear_queue(q);
 		q->realtime = 1;
+		q->membercount = 0;
 		init_queue(q);		/* Ensure defaults for all parameters not set explicitly. */
 		ao2_link(queues, q);
 	}
@@ -5059,6 +5059,7 @@
 		init_queue(q);
 	}
 	if (member_reload) {
+		q->membercount = 0;
 		mem_iter = ao2_iterator_init(q->members, 0);
 		while ((cur = ao2_iterator_next(&mem_iter))) {
 			if (!cur->dynamic)
@@ -5087,7 +5088,10 @@
 	if (member_reload) {
 		mem_iter = ao2_iterator_init(q->members, 0);
 		while ((cur = ao2_iterator_next(&mem_iter))) {
-			if (! cur->delme) {
+			if (!cur->delme) {
+				if (cur->dynamic)
+					q->membercount++;
+				cur->status = ast_device_state(cur->interface);
 				ao2_ref(cur, -1);
 				continue;
 			}
@@ -5121,15 +5125,7 @@
 		return 0;
 	} else if (cfg == CONFIG_STATUS_FILEUNCHANGED)
 		return 0;
-	/* Quick reload if only one queue is being reloaded */
-	if (!ast_strlen_zero(queuename)) {
-		if (!ast_category_exist(cfg, queuename)) {
-			ast_log(LOG_WARNING, "Request for reload on non-existent queue '%s'. Aborting!\n", queuename);
-			return AST_MODULE_LOAD_SUCCESS;
-		}
-		reload_single_queue(cfg, mask, queuename);
-		return AST_MODULE_LOAD_SUCCESS;
-	}
+
 	/* We've made it here, so it looks like we're doing operations on all queues. */
 	ao2_lock(queues);
 	
@@ -5140,7 +5136,7 @@
 		queue_iter = ao2_iterator_init(queues, F_AO2I_DONTLOCK);
 		while ((q = ao2_iterator_next(&queue_iter))) {
 			/* We don't want to affect realtime queues at all during a reload */
-			if (!q->realtime) {
+			if (!q->realtime && (ast_strlen_zero(queuename) || !strcasecmp(queuename, q->name))) {
 				q->dead = 1;
 				q->found = 0;
 			}
@@ -5155,7 +5151,8 @@
 			queue_set_global_params(cfg);
 			continue;
 		}
-		reload_single_queue(cfg, mask, cat);
+		if (ast_strlen_zero(queuename) || !strcasecmp(cat, queuename))
+			reload_single_queue(cfg, mask, cat);
 	}
 	
 	ast_config_destroy(cfg);
@@ -5163,19 +5160,9 @@
 	if (mask & QUEUE_RELOAD) {
 		queue_iter = ao2_iterator_init(queues, 0);
 		while ((q = ao2_iterator_next(&queue_iter))) {
-			if (q->dead) {
+			if ((ast_strlen_zero(queuname) || !strcasecmp(queuename, q->name)) && q->dead) {
 				ao2_unlink(queues, q);
-			} else {
-				ao2_lock(q);
-				mem_iter = ao2_iterator_init(q->members, 0);
-				while ((cur = ao2_iterator_next(&mem_iter))) {
-					if (cur->dynamic)
-						q->membercount++;
-					cur->status = ast_device_state(cur->interface);
-					ao2_ref(cur, -1);
-				}
-				ao2_unlock(q);
-			}
+			} 
 			queue_unref(q);
 		}
 	}




More information about the svn-commits mailing list