[Asterisk-cvs] asterisk/apps app_forkcdr.c,1.10,1.11

kpfleming at lists.digium.com kpfleming at lists.digium.com
Mon Jul 25 18:49:35 CDT 2005


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

Modified Files:
	app_forkcdr.c 
Log Message:
use CDR API calls instead of re-implementing them (bug #4726)


Index: app_forkcdr.c
===================================================================
RCS file: /usr/cvsroot/asterisk/apps/app_forkcdr.c,v
retrieving revision 1.10
retrieving revision 1.11
diff -u -d -r1.10 -r1.11
--- app_forkcdr.c	15 Jul 2005 23:00:46 -0000	1.10
+++ app_forkcdr.c	25 Jul 2005 22:56:18 -0000	1.11
@@ -40,28 +40,21 @@
 
 LOCAL_USER_DECL;
 
-
-static void ast_cdr_clone(struct ast_cdr *cdr) 
-{
-	struct ast_cdr *newcdr = ast_cdr_alloc();
-	memcpy(newcdr,cdr,sizeof(struct ast_cdr));
-	ast_cdr_append(cdr,newcdr);
-	newcdr->start = ast_tvnow();
-	memset(&newcdr->answer, 0, sizeof(newcdr->answer));
-	memset(&newcdr->varshead, 0, sizeof(newcdr->varshead));
-	ast_cdr_copy_vars(newcdr, cdr);
-	if (!ast_test_flag(cdr, AST_CDR_FLAG_KEEP_VARS)) {
-		ast_cdr_free_vars(cdr, 0);
-	}
-	newcdr->disposition = AST_CDR_NOANSWER;
-	ast_set_flag(cdr, AST_CDR_FLAG_CHILD|AST_CDR_FLAG_LOCKED);
-}
-
 static void ast_cdr_fork(struct ast_channel *chan) 
 {
-	if(chan && chan->cdr) {
-		ast_cdr_clone(chan->cdr);
-	}
+	struct ast_cdr *cdr;
+	struct ast_cdr *newcdr;
+	if (!chan || !(cdr = chan->cdr))
+		return;
+	while (cdr->next)
+		cdr = cdr->next;
+	if (!(newcdr = ast_cdr_dup(cdr)))
+		return;
+	ast_cdr_append(cdr, newcdr);
+	ast_cdr_reset(newcdr, AST_CDR_FLAG_KEEP_VARS);
+	if (!ast_test_flag(cdr, AST_CDR_FLAG_KEEP_VARS))
+		ast_cdr_free_vars(cdr, 0);
+	ast_set_flag(cdr, AST_CDR_FLAG_CHILD | AST_CDR_FLAG_LOCKED);
 }
 
 static int forkcdr_exec(struct ast_channel *chan, void *data)




More information about the svn-commits mailing list