mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-25 14:06:27 +00:00
use CDR API calls instead of re-implementing them (bug #4726)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@6213 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -40,28 +40,21 @@ STANDARD_LOCAL_USER;
|
|||||||
|
|
||||||
LOCAL_USER_DECL;
|
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)
|
static void ast_cdr_fork(struct ast_channel *chan)
|
||||||
{
|
{
|
||||||
if(chan && chan->cdr) {
|
struct ast_cdr *cdr;
|
||||||
ast_cdr_clone(chan->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)
|
static int forkcdr_exec(struct ast_channel *chan, void *data)
|
||||||
|
|||||||
4
cdr.c
4
cdr.c
@@ -147,7 +147,7 @@ void ast_cdr_unregister(char *name)
|
|||||||
AST_LIST_UNLOCK(&be_list);
|
AST_LIST_UNLOCK(&be_list);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct ast_cdr *cdr_dup(struct ast_cdr *cdr)
|
struct ast_cdr *ast_cdr_dup(struct ast_cdr *cdr)
|
||||||
{
|
{
|
||||||
struct ast_cdr *newcdr;
|
struct ast_cdr *newcdr;
|
||||||
|
|
||||||
@@ -809,7 +809,7 @@ void ast_cdr_reset(struct ast_cdr *cdr, int flags)
|
|||||||
if (ast_test_flag(&tmp, AST_CDR_FLAG_LOCKED) || !ast_test_flag(cdr, AST_CDR_FLAG_LOCKED)) {
|
if (ast_test_flag(&tmp, AST_CDR_FLAG_LOCKED) || !ast_test_flag(cdr, AST_CDR_FLAG_LOCKED)) {
|
||||||
if (ast_test_flag(&tmp, AST_CDR_FLAG_POSTED)) {
|
if (ast_test_flag(&tmp, AST_CDR_FLAG_POSTED)) {
|
||||||
ast_cdr_end(cdr);
|
ast_cdr_end(cdr);
|
||||||
if ((dup = cdr_dup(cdr))) {
|
if ((dup = ast_cdr_dup(cdr))) {
|
||||||
ast_cdr_detach(dup);
|
ast_cdr_detach(dup);
|
||||||
}
|
}
|
||||||
ast_set_flag(cdr, AST_CDR_FLAG_POSTED);
|
ast_set_flag(cdr, AST_CDR_FLAG_POSTED);
|
||||||
|
|||||||
@@ -104,6 +104,12 @@ typedef int (*ast_cdrbe)(struct ast_cdr *cdr);
|
|||||||
*/
|
*/
|
||||||
extern struct ast_cdr *ast_cdr_alloc(void);
|
extern struct ast_cdr *ast_cdr_alloc(void);
|
||||||
|
|
||||||
|
/*! Duplicate a record */
|
||||||
|
/*!
|
||||||
|
* Returns a malloc'd ast_cdr structure, returns NULL on error (malloc failure)
|
||||||
|
*/
|
||||||
|
extern struct ast_cdr *ast_cdr_dup(struct ast_cdr *cdr);
|
||||||
|
|
||||||
/*! Free a record */
|
/*! Free a record */
|
||||||
/* \param cdr ast_cdr structure to free
|
/* \param cdr ast_cdr structure to free
|
||||||
* Returns nothing important
|
* Returns nothing important
|
||||||
|
|||||||
Reference in New Issue
Block a user