aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-09-10 13:40:56 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-09-10 13:40:56 +0000
commitd1fab10737f98b505b68db7849a15206c6390539 (patch)
tree2021c8850797d84a6ca6817164783ea3c37616d3
parenta1f2f5b139f245001c0b680c57d41091cfeef015 (diff)
Handle macros in the CDR properly (bug #2414)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@3758 f38db490-d61c-443f-a65b-d21fe96a405b
-rwxr-xr-xcdr.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/cdr.c b/cdr.c
index a078c15eb..8057fa1aa 100755
--- a/cdr.c
+++ b/cdr.c
@@ -3,9 +3,9 @@
*
* Call Detail Record API
*
- * Copyright (C) 1999, Mark Spencer
+ * Copyright (C) 1999-2004, Digium, Inc.
*
- * Mark Spencer <markster@linux-support.net>
+ * Mark Spencer <markster@digium.com>
*
* This program is free software, distributed under the terms of
* the GNU General Public License.
@@ -442,8 +442,14 @@ int ast_cdr_update(struct ast_channel *c)
/* Copy account code et-al */
strncpy(cdr->accountcode, c->accountcode, sizeof(cdr->accountcode) - 1);
/* Destination information */
- strncpy(cdr->dst, c->exten, sizeof(cdr->dst) - 1);
- strncpy(cdr->dcontext, c->context, sizeof(cdr->dcontext) - 1);
+ if (ast_strlen_zero(c->macroexten))
+ strncpy(cdr->dst, c->exten, sizeof(cdr->dst) - 1);
+ else
+ strncpy(cdr->dst, c->macroexten, sizeof(cdr->dst) - 1);
+ if (ast_strlen_zero(c->macrocontext))
+ strncpy(cdr->dcontext, c->context, sizeof(cdr->dcontext) - 1);
+ else
+ strncpy(cdr->dcontext, c->macrocontext, sizeof(cdr->dcontext) - 1);
}
cdr = cdr->next;
}