Handle macros in the CDR properly (bug #2414)
authorMark Spencer <markster@digium.com>
Fri, 10 Sep 2004 13:40:56 +0000 (13:40 +0000)
committerMark Spencer <markster@digium.com>
Fri, 10 Sep 2004 13:40:56 +0000 (13:40 +0000)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@3758 65c4cc65-6c06-0410-ace0-fbb531ad65f3

cdr.c

diff --git a/cdr.c b/cdr.c
index a078c15..8057fa1 100755 (executable)
--- 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;
        }