mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-26 14:27:14 +00:00 
			
		
		
		
	Pick the right point for rebuilding the list
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@1367 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -244,7 +244,7 @@ ast_log(LOG_NOTICE, "Queue '%s' Join, Channel '%s', Position '%d'\n", q->name, q | |||||||
| 	return res; | 	return res; | ||||||
| } | } | ||||||
|  |  | ||||||
| static void free_members(struct ast_call_queue *q) | static void free_members(struct ast_call_queue *q, int all) | ||||||
| { | { | ||||||
| 	/* Free non-dynamic members */ | 	/* Free non-dynamic members */ | ||||||
| 	struct member *curm, *next, *prev; | 	struct member *curm, *next, *prev; | ||||||
| @@ -252,7 +252,7 @@ static void free_members(struct ast_call_queue *q) | |||||||
| 	prev = NULL; | 	prev = NULL; | ||||||
| 	while(curm) { | 	while(curm) { | ||||||
| 		next = curm->next; | 		next = curm->next; | ||||||
| 		if (!curm->dynamic) { | 		if (all || !curm->dynamic) { | ||||||
| 			if (prev) | 			if (prev) | ||||||
| 				prev->next = next; | 				prev->next = next; | ||||||
| 			else | 			else | ||||||
| @@ -281,7 +281,7 @@ static void destroy_queue(struct ast_call_queue *q) | |||||||
| 		cur = cur->next; | 		cur = cur->next; | ||||||
| 	} | 	} | ||||||
| 	ast_mutex_unlock(&qlock); | 	ast_mutex_unlock(&qlock); | ||||||
| 	free_members(q); | 	free_members(q, 1); | ||||||
| 	free(q); | 	free(q); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -1237,11 +1237,16 @@ static void reload_queues(void) | |||||||
| 				q->retry = 0; | 				q->retry = 0; | ||||||
| 				q->timeout = -1; | 				q->timeout = -1; | ||||||
| 				q->maxlen = 0; | 				q->maxlen = 0; | ||||||
| 				free_members(q); | 				free_members(q, 0); | ||||||
| 				strcpy(q->moh, ""); | 				strcpy(q->moh, ""); | ||||||
| 				strcpy(q->announce, ""); | 				strcpy(q->announce, ""); | ||||||
| 				strcpy(q->context, ""); | 				strcpy(q->context, ""); | ||||||
| 				prev = NULL; | 				prev = q->members; | ||||||
|  | 				if (prev) { | ||||||
|  | 					/* find the end of any dynamic members */ | ||||||
|  | 					while(prev->next) | ||||||
|  | 						prev = prev->next; | ||||||
|  | 				} | ||||||
| 				var = ast_variable_browse(cfg, cat); | 				var = ast_variable_browse(cfg, cat); | ||||||
| 				while(var) { | 				while(var) { | ||||||
| 					if (!strcasecmp(var->name, "member")) { | 					if (!strcasecmp(var->name, "member")) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user