summaryrefslogtreecommitdiff
path: root/channels
diff options
context:
space:
mode:
authorMark Michelson <mmichelson@digium.com>2009-04-10 16:26:48 +0000
committerMark Michelson <mmichelson@digium.com>2009-04-10 16:26:48 +0000
commit9b580ea6456f0fd56ff22b11e8cc4d683d5a3376 (patch)
tree5108f44ee609ac3e3cda74e5eee9397a45a0e156 /channels
parentbdcf8fca816de8cd5420a17582907fecb5321480 (diff)
ast_strdup failures aren't really failures if the original value was NULL.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@187714 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_local.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/channels/chan_local.c b/channels/chan_local.c
index 509e69b10..89a77d838 100644
--- a/channels/chan_local.c
+++ b/channels/chan_local.c
@@ -566,13 +566,17 @@ start_over:
* All these failure points just return -1. The individual strings will
* be cleared when we destroy the channel.
*/
- if (!(p->chan->cid.cid_rdnis = ast_strdup(p->owner->cid.cid_rdnis))) {
- return -1;
+ if (p->owner->cid.cid_rdnis) {
+ if (!(p->chan->cid.cid_rdnis = ast_strdup(p->owner->cid.cid_rdnis))) {
+ return -1;
+ }
}
ast_party_redirecting_copy(&p->chan->redirecting, &p->owner->redirecting);
- if (!(p->chan->cid.cid_dnid = ast_strdup(p->owner->cid.cid_dnid))) {
- return -1;
+ if (p->owner->cid.cid_dnid) {
+ if (!(p->chan->cid.cid_dnid = ast_strdup(p->owner->cid.cid_dnid))) {
+ return -1;
+ }
}
p->chan->cid.cid_tns = p->owner->cid.cid_tns;