aboutsummaryrefslogtreecommitdiffstats
path: root/channels/chan_local.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-10-02 00:58:31 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-10-02 00:58:31 +0000
commit6868babd229a635c5fd89c7b284025a92e0a3f9d (patch)
tree25a4ee6dff29d18acfdfbbc42485333db7aa5311 /channels/chan_local.c
parentb201da1a3eb1cae654cdd3fe89ef8f9e55dd0b83 (diff)
Huge callerid rework (might break H.323, others)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@3874 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_local.c')
-rwxr-xr-xchannels/chan_local.c28
1 files changed, 18 insertions, 10 deletions
diff --git a/channels/chan_local.c b/channels/chan_local.c
index fc8fd8820..4c50720dc 100755
--- a/channels/chan_local.c
+++ b/channels/chan_local.c
@@ -239,18 +239,26 @@ static int local_call(struct ast_channel *ast, char *dest, int timeout)
int res;
ast_mutex_lock(&p->lock);
- if (p->owner->callerid)
- p->chan->callerid = strdup(p->owner->callerid);
+ if (p->owner->cid.cid_num)
+ p->chan->cid.cid_num = strdup(p->owner->cid.cid_num);
+ else
+ p->chan->cid.cid_num = NULL;
+
+ if (p->owner->cid.cid_name)
+ p->chan->cid.cid_name = strdup(p->owner->cid.cid_name);
+ else
+ p->chan->cid.cid_name = NULL;
+
+ if (p->owner->cid.cid_rdnis)
+ p->chan->cid.cid_rdnis = strdup(p->owner->cid.cid_rdnis);
else
- p->chan->callerid = NULL;
- if (p->owner->rdnis)
- p->chan->rdnis = strdup(p->owner->rdnis);
- else
- p->chan->rdnis = NULL;
- if (p->owner->ani)
- p->chan->ani = strdup(p->owner->ani);
+ p->chan->cid.cid_rdnis = NULL;
+
+ if (p->owner->cid.cid_ani)
+ p->chan->cid.cid_ani = strdup(p->owner->cid.cid_ani);
else
- p->chan->ani = NULL;
+ p->chan->cid.cid_ani = NULL;
+
strncpy(p->chan->language, p->owner->language, sizeof(p->chan->language) - 1);
strncpy(p->chan->accountcode, p->owner->accountcode, sizeof(p->chan->accountcode) - 1);
p->chan->cdrflags = p->owner->cdrflags;