[svn-commits] mmichelson: branch group/CCSS_Monitor_Restructure r242416 - in /team/group/CC...
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Fri Jan 22 14:28:42 CST 2010
    
    
  
Author: mmichelson
Date: Fri Jan 22 14:28:39 2010
New Revision: 242416
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=242416
Log:
Remove agent->interface_tree since the core_instance has that information
and there's no need to duplicate it.
Modified:
    team/group/CCSS_Monitor_Restructure/include/asterisk/ccss.h
    team/group/CCSS_Monitor_Restructure/main/ccss.c
Modified: team/group/CCSS_Monitor_Restructure/include/asterisk/ccss.h
URL: http://svnview.digium.com/svn/asterisk/team/group/CCSS_Monitor_Restructure/include/asterisk/ccss.h?view=diff&rev=242416&r1=242415&r2=242416
==============================================================================
--- team/group/CCSS_Monitor_Restructure/include/asterisk/ccss.h (original)
+++ team/group/CCSS_Monitor_Restructure/include/asterisk/ccss.h Fri Jan 22 14:28:39 2010
@@ -722,18 +722,6 @@
 	 * agent's operation.
 	 */
 	struct ast_cc_config_params *cc_params;
-	/*!
-	 * \brief The "tree" of interfaces dialed by the caller
-	 *
-	 * \details
-	 * In actuality, this is a linked list. Each element
-	 * contains an integer which tells who its parent is
-	 * in the tree. The tree is arranged in such a way that
-	 * all children of an interface will always appear later
-	 * in the list. We take advantage of this fact later when
-	 * creating the monitor structure.
-	 */
-	struct ast_cc_interface_tree *interface_tree;
 	/*!
 	 * \brief Flags for agent operation
 	 *
Modified: team/group/CCSS_Monitor_Restructure/main/ccss.c
URL: http://svnview.digium.com/svn/asterisk/team/group/CCSS_Monitor_Restructure/main/ccss.c?view=diff&rev=242416&r1=242415&r2=242416
==============================================================================
--- team/group/CCSS_Monitor_Restructure/main/ccss.c (original)
+++ team/group/CCSS_Monitor_Restructure/main/ccss.c Fri Jan 22 14:28:39 2010
@@ -155,6 +155,15 @@
 };
 
 /*!
+ * \brief The "tree" of interfaces that is dialed.
+ *
+ * It is reference counted since several threads may need
+ * to use it, and it may last beyond the lifetime of a single
+ * thread.
+ */
+AST_DLLIST_HEAD(ast_cc_interface_tree, cc_monitor);
+
+/*!
  * \internal
  * \brief Request that the core change states
  * \param state The state to which we wish to change
@@ -1208,15 +1217,6 @@
 	cc_unref(generic_list, "Done with generic list in generic monitor destructor");
 	ast_free((char *)gen_mon_pvt->device_name);
 }
-
-/*!
- * \brief The "tree" of interfaces that is dialed.
- *
- * It is reference counted since several threads may need
- * to use it, and it may last beyond the lifetime of a single
- * thread.
- */
-AST_DLLIST_HEAD(ast_cc_interface_tree, cc_monitor);
 
 static void cc_interface_destroy(void *data)
 {
@@ -1856,7 +1856,6 @@
 	if (agent->callbacks) {
 		agent->callbacks->destructor(agent);
 	}
-	agent->interface_tree = cc_unref(agent->interface_tree, "Destroying agent, removing ref to interface tree");
 	ast_cc_config_params_destroy(agent->cc_params);
 }
 
@@ -1873,7 +1872,6 @@
 
 	agent->core_id = core_id;
 	strcpy(agent->interface, caller_name);
-	agent->interface_tree = cc_ref(interface_tree, "Agent now has reference to interface tree");
 
 	cc_params = ast_channel_get_cc_config_params(caller_chan);
 	if (!cc_params) {
@@ -1956,6 +1954,22 @@
 	 * is the caller's name.
 	 */
 	char cid_name[AST_CHANNEL_NAME];
+	/*!
+	 * Extension dialed
+	 *
+	 * The original extension dialed. This is used
+	 * so that when performing a recall, we can
+	 * call the proper extension.
+	 */
+	char exten[AST_CHANNEL_NAME];
+	/*!
+	 * Context dialed
+	 *
+	 * The original context dialed. This is used
+	 * so that when performaing a recall, we can
+	 * call into the proper context
+	 */
+	char context[AST_CHANNEL_NAME];
 };
 
 static int cc_generic_agent_init(struct ast_cc_agent *agent, struct ast_channel *chan)
@@ -1969,6 +1983,8 @@
 	generic_pvt->offer_timer_id = -1;
 	ast_copy_string(generic_pvt->cid_num, chan->cid.cid_num, sizeof(generic_pvt->cid_num));
 	ast_copy_string(generic_pvt->cid_name, chan->cid.cid_name, sizeof(generic_pvt->cid_name));
+	ast_copy_string(generic_pvt->exten, S_OR(chan->macroexten, chan->exten), sizeof(generic_pvt->exten));
+	ast_copy_string(generic_pvt->context, S_OR(chan->macrocontext, chan->context), sizeof(generic_pvt->context));
 	agent->private_data = generic_pvt;
 	ast_set_flag(agent, AST_CC_AGENT_SKIP_OFFER);
 	return 0;
@@ -2092,10 +2108,6 @@
 	char *target;
 	int reason;
 	struct ast_channel *chan;
-	struct cc_monitor *monitor = AST_DLLIST_FIRST(agent->interface_tree);
-	char *full_extension = ast_strdupa(monitor->interface->name);
-	char *context;
-	char *exten;
 	const char *callback_macro = ast_get_cc_callback_macro(agent->cc_params);
 
 	tech = interface;
@@ -2123,14 +2135,10 @@
 	 * function to do so.
 	 */
 	ast_setup_cc_recall_datastore(chan, agent->core_id);
-	ast_set_cc_interfaces_chanvar(chan, full_extension);
-	/* Now we can bust apart the outbound name so that the PBX will run. */
-	exten = full_extension;
-	if ((context = strchr(full_extension, '@'))) {
-		*context++ = '\0';
-	}
-	ast_copy_string(chan->exten, exten, sizeof(chan->exten));
-	ast_copy_string(chan->context, context, sizeof(chan->context));
+	ast_cc_agent_set_interfaces_chanvar(chan, agent);
+	
+	ast_copy_string(chan->exten, generic_pvt->exten, sizeof(chan->exten));
+	ast_copy_string(chan->context, generic_pvt->context, sizeof(chan->context));
 	chan->priority = 1;
 	ast_cc_agent_recalling(agent->core_id, "Generic agent is recalling");
 	ast_pbx_start(chan);
@@ -2636,7 +2644,7 @@
 		return -1;
 	}
 
-	recall_data->interface_tree = cc_ref(core_instance->agent->interface_tree,
+	recall_data->interface_tree = cc_ref(core_instance->monitors,
 			"Bump refcount for interface tree for agent");
 	recall_data->core_id = core_id;
 	recall_datastore->data = recall_data;
    
    
More information about the svn-commits
mailing list