Update of /usr/cvsroot/asterisk/channels
In directory mongoose.digium.com:/tmp/cvs-serv31924/channels

Modified Files:
        chan_sip.c 
Log Message:
fix reply_digest breakage from earlier patch


Index: chan_sip.c
===================================================================
RCS file: /usr/cvsroot/asterisk/channels/chan_sip.c,v
retrieving revision 1.765
retrieving revision 1.766
diff -u -d -r1.765 -r1.766
--- chan_sip.c  19 Jun 2005 22:00:18 -0000      1.765
+++ chan_sip.c  20 Jun 2005 17:01:03 -0000      1.766
@@ -7772,29 +7772,24 @@
                i->dst[0] = '\0';       /* init all to empty strings */
        while (c && *(c = ast_skip_blanks(c))) {        /* lookup for keys */
                for (i = keys; i->key != NULL; i++) {
-                       char *src;
+                       char *src, *separator;
                        if (strncasecmp(c, i->key, strlen(i->key)) != 0)
                                continue;
                        /* Found. Skip keyword, take text in quotes or up to 
the separator. */
                        c += strlen(i->key);
-                       if ((*c == '\"')) {
+                       if (*c == '\"') {
                                src = ++c;
-                               if ((c = strchr(c,'\"'))) {
-                                       *c = '\0';
-                                       c++;
-                               }
+                               separator = "\"";
                        } else {
                                src = c;
-                               if ((c = strchr(c,','))) {
-                                       *c = '\0';
-                                       c++;
-                               }
+                               separator = ",";
                        }
+                       strsep(&c, separator); /* clear separator and move ptr 
*/
                        ast_copy_string(i->dst, src, i->dstlen);
                        break;
                }
-               if (i->key == NULL)
-                       c = strchr(c,',');
+               if (i->key == NULL) /* not found, try ',' */
+                       strsep(&c, ",");
        }
 
        /* Save auth data for following registrations */

_______________________________________________
Asterisk-Cvs mailing list
[email protected]
http://lists.digium.com/mailman/listinfo/asterisk-cvs

Reply via email to