[svn-commits] seanbright: branch seanbright/issue5014-1.4 r145258 - /team/seanbright/issue5...
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Tue Sep 30 17:26:05 CDT 2008
    
    
  
Author: seanbright
Date: Tue Sep 30 17:26:04 2008
New Revision: 145258
URL: http://svn.digium.com/view/asterisk?view=rev&rev=145258
Log:
 - kill off pickup_target struct and localize its usage to the function it was
   used in
 - use a single call to ast_build_string() for inserting dialog-info bits
 - use stack instead of heap for the Pickup app args in the magic pickup function
 - use stack for the pickup target info in the invite handler
Modified:
    team/seanbright/issue5014-1.4/channels/chan_sip.c
Modified: team/seanbright/issue5014-1.4/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/seanbright/issue5014-1.4/channels/chan_sip.c?view=diff&rev=145258&r1=145257&r2=145258
==============================================================================
--- team/seanbright/issue5014-1.4/channels/chan_sip.c (original)
+++ team/seanbright/issue5014-1.4/channels/chan_sip.c Tue Sep 30 17:26:04 2008
@@ -873,13 +873,6 @@
         REFER_200OK,                   /*!< Answered by transfer target */
         REFER_FAILED,                  /*!< REFER declined - go on */
         REFER_NOAUTH                   /*!< We had no auth for REFER */
-};
-
-/*! \brief struct to store off exten and contact for tech independent pickup.
- */
-struct pickup_target {
-	char *exten;
-	char *context;
 };
 
 static const struct c_referstatusstring {
@@ -7401,18 +7394,20 @@
 		if ((state & AST_EXTENSION_RINGING) && global_notifyringing) {
 			/* We create a fake call-id which the phone will send back in an INVITE
 			   Replaces header which we can grab and do some magic with. */
-			ast_build_string(&t, &maxbytes, "<dialog id=\"%s\" call-id=\"pickup-%s\" direction=\"recipient\">\n", p->exten, p->callid);
-			ast_build_string(&t, &maxbytes, "<remote>\n");
-			/* Note that the identity and target elements for the local participant are currently
-			   (and may forever be) incorrect since we have no reliable way to get at that information
-			   at the moment.  Luckily the phone seems to still live happily without it being correct */
-			ast_build_string(&t, &maxbytes, "<identity>%s</identity>\n", mto);
-			ast_build_string(&t, &maxbytes, "<target uri=\"%s\"/>\n", mto);
-			ast_build_string(&t, &maxbytes, "</remote>\n");
-			ast_build_string(&t, &maxbytes, "<local>\n");
-			ast_build_string(&t, &maxbytes, "<identity>%s</identity>\n", mto);
-			ast_build_string(&t, &maxbytes, "<target uri=\"%s\"/>\n", mto);
-			ast_build_string(&t, &maxbytes, "</local>\n");
+			ast_build_string(&t, &maxbytes,
+							 "<dialog id=\"%s\" call-id=\"pickup-%s\" direction=\"recipient\">\n"
+							 "<remote>\n"
+							 /* Note that the identity and target elements for the local participant are currently
+								(and may forever be) incorrect since we have no reliable way to get at that information
+								at the moment.  Luckily the phone seems to still live happily without it being correct */
+							 "<identity>%s</identity>\n"
+							 "<target uri=\"%s\"/>\n"
+							 "</remote>\n"
+							 "<local>\n"
+							 "<identity>%s</identity>\n"
+							 "<target uri=\"%s\"/>\n"
+							 "</local>\n",
+							 p->exten, p->callid, mto, mto, mto, mto);
 		} else {
 			ast_build_string(&t, &maxbytes, "<dialog id=\"%s\">\n", p->exten);
 		}
@@ -14105,20 +14100,12 @@
 
 static int do_magic_pickup(struct ast_channel *channel, const char *extension, const char *context)
 {
-	char *argument = NULL;
-	int length;
+	int length = AST_MAX_EXTENSION + AST_MAX_CONTEXT + 2;
+	char *argument = alloca(length);
 	struct ast_app *pickup = pbx_findapp("Pickup");
 
 	if (!pickup) {
 		ast_log(LOG_ERROR, "Unable to perform pickup: Application 'Pickup' not loaded (app_directed_pickup.so).\n");
-		return -1;
-	}
-
-	/* Enough room for 'extension', 'context', and '@' (and \0) */
-	length = strlen(extension) + strlen(context) + 2;
-
-	if (!(argument = ast_malloc(length))) {
-		ast_log(LOG_ERROR, "Failed to allocate memory for pickup extension.\n");
 		return -1;
 	}
 
@@ -14128,8 +14115,6 @@
 	   doesn't return anything meaningful unless the passed data is an empty
 	   string (which in our case it will not be) */
 	pbx_exec(channel, pickup, argument);
-
-	ast_free(argument);
 
 	return 0;	
 }
@@ -14150,7 +14135,12 @@
 	unsigned int required_profile = 0;
 	struct ast_channel *c = NULL;		/* New channel */
 	int reinvite = 0;
-	struct pickup_target *pickup = NULL;
+	struct {
+		char exten[AST_MAX_EXTENSION];
+		char context[AST_MAX_CONTEXT];
+	} pickup = {
+		.exten = "",
+	};
 
 	/* Find out what they support */
 	if (!p->sipoptions) {
@@ -14300,22 +14290,17 @@
 				transmit_response_reliable(p, "481 Call Leg Does Not Exist (Replaces)", req);
 				error = 1;
 			} else {
-				if (!(pickup = ast_calloc(1, sizeof(*pickup)))) {
-					ast_log(LOG_ERROR, "Memory allocation failed.\n");
-					error = 1;
-				} else {
-					ast_log(LOG_NOTICE, "Trying to pick up %s@%s\n", subscription->exten, subscription->context);
-					pickup->exten   = ast_strdup(subscription->exten);
-					pickup->context = ast_strdup(subscription->context);
-					ast_mutex_unlock(&subscription->lock);
-					if (subscription->owner) {
-						ast_channel_unlock(subscription->owner);
-					}
+				ast_log(LOG_NOTICE, "Trying to pick up %s@%s\n", subscription->exten, subscription->context);
+				ast_copy_string(pickup.exten, subscription->exten, sizeof(pickup.exten));
+				ast_copy_string(pickup.context, subscription->context, sizeof(pickup.context));
+				ast_mutex_unlock(&subscription->lock);
+				if (subscription->owner) {
+					ast_channel_unlock(subscription->owner);
 				}
 			}
 		}
 
-		if (!error && !pickup && (p->refer->refer_call = get_sip_pvt_byid_locked(replace_id, totag, fromtag)) == NULL) {
+		if (!error && ast_strlen_zero(pickup.exten) && (p->refer->refer_call = get_sip_pvt_byid_locked(replace_id, totag, fromtag)) == NULL) {
 			ast_log(LOG_NOTICE, "Supervised transfer attempted to replace non-existent call id (%s)!\n", replace_id);
 			transmit_response_reliable(p, "481 Call Leg Does Not Exist (Replaces)", req);
 			error = 1;
@@ -14334,7 +14319,7 @@
 			error = 1;
 		}
 
-		if (!error && !pickup && !p->refer->refer_call->owner) {
+		if (!error && ast_strlen_zero(pickup.exten) && !p->refer->refer_call->owner) {
 			/* Oops, someting wrong anyway, no owner, no call */
 			ast_log(LOG_NOTICE, "Supervised transfer attempted to replace non-existing call id (%s)!\n", replace_id);
 			/* Check for better return code */
@@ -14342,7 +14327,7 @@
 			error = 1;
 		}
 
-		if (!error && !pickup && p->refer->refer_call->owner->_state != AST_STATE_RINGING && p->refer->refer_call->owner->_state != AST_STATE_RING && p->refer->refer_call->owner->_state != AST_STATE_UP ) {
+		if (!error && ast_strlen_zero(pickup.exten) && p->refer->refer_call->owner->_state != AST_STATE_RINGING && p->refer->refer_call->owner->_state != AST_STATE_RING && p->refer->refer_call->owner->_state != AST_STATE_UP ) {
 			ast_log(LOG_NOTICE, "Supervised transfer attempted to replace non-ringing or active call id (%s)!\n", replace_id);
 			transmit_response_reliable(p, "603 Declined (Replaces)", req);
 			error = 1;
@@ -14532,7 +14517,7 @@
 		p->lastinvite = seqno;
 
 	if (replace_id) { 	/* Attended transfer or call pickup - we're the target */
-		if (pickup) {
+		if (!ast_strlen_zero(pickup.exten)) {
 			append_history(p, "Xfer", "INVITE/Replace received");
 
 			/* Let the caller know we're giving it a shot */
@@ -14542,15 +14527,11 @@
 			/* Do the pickup itself */
 			ast_channel_unlock(c);
 			*nounlock = 1;
-			do_magic_pickup(c, pickup->exten, pickup->context);
+			do_magic_pickup(c, pickup.exten, pickup.context);
 
 			/* Now we're either masqueraded or we failed to pickup, in either case we... */
 			ast_hangup(c);
 
-			/* Do a bit of cleanup */
-			ast_free(pickup->exten);
-			ast_free(pickup->context);
-			ast_free(pickup);
 			return 0;
 		} else {
 			/* Go and take over the target call */
    
    
More information about the svn-commits
mailing list