diff options
author | murf <murf@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-11-07 21:47:49 +0000 |
---|---|---|
committer | murf <murf@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-11-07 21:47:49 +0000 |
commit | 4d6996c27ad2cc1e0055b06b18522a44036c4f5c (patch) | |
tree | c85e2036ae8d28edebee2af6cc055a51e39ba1da /channels/chan_agent.c | |
parent | c347b4f11cda5733f217deac8c9f852fc46945f0 (diff) |
A fair number of changes for the sake of bug 7506
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@47290 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_agent.c')
-rw-r--r-- | channels/chan_agent.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 4eff85fdb..40909b21d 100644 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -905,7 +905,10 @@ static struct ast_channel *agent_new(struct agent_pvt *p, int state) return NULL; } #endif - tmp = ast_channel_alloc(0); + if (p->pending) + tmp = ast_channel_alloc(0, state, 0, 0, "Agent/P%s-%d", p->agent, ast_random() & 0xffff); + else + tmp = ast_channel_alloc(0, state, 0, 0, "Agent/%s", p->agent); if (!tmp) { ast_log(LOG_WARNING, "Unable to allocate agent channel structure\n"); return NULL; @@ -929,12 +932,7 @@ static struct ast_channel *agent_new(struct agent_pvt *p, int state) tmp->readformat = AST_FORMAT_SLINEAR; tmp->rawreadformat = AST_FORMAT_SLINEAR; } - if (p->pending) - ast_string_field_build(tmp, name, "Agent/P%s-%d", p->agent, ast_random() & 0xffff); - else - ast_string_field_build(tmp, name, "Agent/%s", p->agent); /* Safe, agentlock already held */ - ast_setstate(tmp, state); tmp->tech_pvt = p; p->owner = tmp; tmp->priority = 1; |