[Asterisk-cvs] asterisk/channels chan_phone.c,1.25,1.26

markster at lists.digium.com markster at lists.digium.com
Sun Jun 6 01:59:24 CDT 2004


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

Modified Files:
	chan_phone.c 
Log Message:
Try to parse callerid properly on /dev/phone (bug #1788)


Index: chan_phone.c
===================================================================
RCS file: /usr/cvsroot/asterisk/channels/chan_phone.c,v
retrieving revision 1.25
retrieving revision 1.26
diff -u -d -r1.25 -r1.26
--- chan_phone.c	16 May 2004 17:54:53 -0000	1.25
+++ chan_phone.c	6 Jun 2004 07:01:37 -0000	1.26
@@ -23,6 +23,7 @@
 #include <asterisk/pbx.h>
 #include <asterisk/options.h>
 #include <asterisk/utils.h>
+#include <asterisk/callerid.h>
 #include <sys/socket.h>
 #include <sys/time.h>
 #include <errno.h>
@@ -156,7 +157,6 @@
 	PHONE_CID cid;
 	time_t UtcTime;
 	struct tm tm;
-	char *s;
 
 	/* display caller id if present */
 	if (ast->callerid) {
@@ -170,14 +170,23 @@
 			sprintf(cid.min,   "%02d", tm.tm_min);
 		}
 		/* the format of ast->callerid is always:  "name" <number> */
-		if(ast_strlen_zero(ast->callerid)){
+		if(!ast->callerid || ast_strlen_zero(ast->callerid)){
 			strcpy(cid.name,DEFAULT_CALLER_ID);
 			cid.number[0]='\0';
 		} else {
-			s=strncpy(cid.name,ast->callerid+1,sizeof(cid.name));
-			(void)strsep(&s,"\"");
-			s=strncpy(cid.number,strrchr(ast->callerid,'<')+1,sizeof(cid.number));
-			(void)strsep(&s,">");
+			char *n, *l;
+			char callerid[256] = "";
+			strncpy(callerid, ast->callerid, sizeof(callerid) - 1);
+			ast_callerid_parse(ast->callerid, &n, &l);
+			if (l) {
+				ast_shrink_phone_number(l);
+				if (!ast_isphonenumber(l))
+					l = NULL;
+			}
+			if (l)
+				strncpy(cid.number, l, sizeof(cid.number) - 1);
+			if (n)
+				strncpy(cid.name, n, sizeof(cid.name) - 1);
 		}
 	}
 




More information about the svn-commits mailing list