don't calculate a duration if the CDR wasn't started, as it will result in a
authorRussell Bryant <russell@russellbryant.com>
Wed, 15 Mar 2006 21:59:08 +0000 (21:59 +0000)
committerRussell Bryant <russell@russellbryant.com>
Wed, 15 Mar 2006 21:59:08 +0000 (21:59 +0000)
totally bogus value.  Thanks, Luigi!  :)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@13132 65c4cc65-6c06-0410-ace0-fbb531ad65f3

cdr.c

diff --git a/cdr.c b/cdr.c
index 95cc898..0aa7ddb 100644 (file)
--- a/cdr.c
+++ b/cdr.c
@@ -653,11 +653,12 @@ void ast_cdr_end(struct ast_cdr *cdr)
                chan = !ast_strlen_zero(cdr->channel) ? cdr->channel : "<unknown>";
                if (ast_test_flag(cdr, AST_CDR_FLAG_POSTED))
                        ast_log(LOG_WARNING, "CDR on channel '%s' already posted\n", chan);
-               if (ast_tvzero(cdr->start))
-                       ast_log(LOG_WARNING, "CDR on channel '%s' has not started\n", chan);
                if (ast_tvzero(cdr->end))
                        cdr->end = ast_tvnow();
-               cdr->duration = cdr->end.tv_sec - cdr->start.tv_sec;
+               if (ast_tvzero(cdr->start))
+                       ast_log(LOG_WARNING, "CDR on channel '%s' has not started\n", chan);
+               else
+                       cdr->duration = cdr->end.tv_sec - cdr->start.tv_sec;
                if (!ast_tvzero(cdr->answer))
                        cdr->billsec = cdr->end.tv_sec - cdr->answer.tv_sec;
                else