From c25499d6c75ea145820465178ef982d256432bc6 Mon Sep 17 00:00:00 2001 From: murf Date: Tue, 7 Nov 2006 23:46:41 +0000 Subject: These mods are to solve the problem in bug 7506. It's a lot of rework to solve a fairly small problem... such is life. git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.4@47303 f38db490-d61c-443f-a65b-d21fe96a405b --- channels/chan_agent.c | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) (limited to 'channels/chan_agent.c') diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 23ef874f1..4d614e945 100644 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -910,7 +910,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; @@ -934,12 +937,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; /* XXX: this needs fixing */ -- cgit v1.2.3