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

markster at lists.digium.com markster at lists.digium.com
Sun May 16 13:43:15 CDT 2004


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

Modified Files:
	chan_phone.c 
Log Message:
Fix callerid on quicknet stuff (bug #1613)


Index: chan_phone.c
===================================================================
RCS file: /usr/cvsroot/asterisk/channels/chan_phone.c,v
retrieving revision 1.24
retrieving revision 1.25
diff -u -d -r1.24 -r1.25
--- chan_phone.c	6 Apr 2004 22:17:31 -0000	1.24
+++ chan_phone.c	16 May 2004 17:54:53 -0000	1.25
@@ -22,6 +22,7 @@
 #include <asterisk/module.h>
 #include <asterisk/pbx.h>
 #include <asterisk/options.h>
+#include <asterisk/utils.h>
 #include <sys/socket.h>
 #include <sys/time.h>
 #include <errno.h>
@@ -35,6 +36,7 @@
 #include <linux/ixjuser.h>
 #include "DialTone.h"
 
+#define DEFAULT_CALLER_ID "Unknown"
 #define PHONE_MAX_BUF 480
 #define DEFAULT_GAIN 0x100
 
@@ -151,25 +153,32 @@
 {
 	struct phone_pvt *p;
 
-	// CID stuff for the phonejack...
-
 	PHONE_CID cid;
 	time_t UtcTime;
 	struct tm tm;
+	char *s;
 
-
+	/* display caller id if present */
 	if (ast->callerid) {
 		time(&UtcTime);
 		localtime_r(&UtcTime,&tm);
 
 		if(&tm != NULL) {
 			sprintf(cid.month, "%02d",(tm.tm_mon + 1));
-			sprintf(cid.day, "%02d", tm.tm_mday);
-			sprintf(cid.hour, "%02d", tm.tm_hour);
-			sprintf(cid.min, "%02d", tm.tm_min);
+			sprintf(cid.day,   "%02d", tm.tm_mday);
+			sprintf(cid.hour,  "%02d", tm.tm_hour);
+			sprintf(cid.min,   "%02d", tm.tm_min);
+		}
+		/* the format of ast->callerid is always:  "name" <number> */
+		if(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,">");
 		}
-		strcpy(cid.name, "Unknown");
-		sprintf(cid.number,"%s",ast->callerid);
 	}
 
 	p = ast->pvt->pvt;
@@ -274,7 +283,7 @@
 		if (p->lastinput != AST_FORMAT_ULAW) {
 			p->lastinput = AST_FORMAT_ULAW;
 			if (ioctl(p->fd, PHONE_REC_CODEC, ULAW)) {
-				ast_log(LOG_WARNING, "Failed to set codec to signed linear 16\n");
+				ast_log(LOG_WARNING, "Failed to set codec to uLaw\n");
 				return -1;
 			}
 		}




More information about the svn-commits mailing list