[asterisk-dev] [Code Review] app_directed_pickup Implement the ability to remove a channel group on bridged channel

Alec Davis reviewboard at asterisk.org
Thu Apr 28 03:26:45 CDT 2011


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://reviewboard.asterisk.org/r/1118/#review3449
-----------------------------------------------------------


I sort of see where your coming from releasing the target before the ast_channel_masquerade, but I don't think it's necessary, as I understand it's ast_do_masquerade that requires all locks to be released before its executed.


/trunk/apps/app_directed_pickup.c
<https://reviewboard.asterisk.org/r/1118/#comment7084>

    do we have a ref leak here, particulary when the code path could fail above is ast_answer fails?



/trunk/main/channel.c
<https://reviewboard.asterisk.org/r/1118/#comment7085>

    The idea of locking the channels container was to stall all other masquerades.


- Alec


On 2011-04-27 08:39:15, irroot wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://reviewboard.asterisk.org/r/1118/
> -----------------------------------------------------------
> 
> (Updated 2011-04-27 08:39:15)
> 
> 
> Review request for Asterisk Developers.
> 
> 
> Summary
> -------
> 
> as a companion to 0018825 to aid with the move from call-limits to channel group variables. the problem with pickup and queue is that they manage channels outside the dialplan and need "helpers" to deal with channel groups.
> 
> in the case of pickup when a call is placed to a extension with say a "<EXTEN>@called" channel group when it is picked up this needs to be cleared to allow further calls when call waiting is disabled.
> 
> exten => s,n,GotoIf($[$[${ GROUP_COUNT(${ARG1}@called)} >= 1] | $[${GROUP_COUNT(${ARG1}@caller)} >= 1] | $[${GROUP_COUNT(${ARG1}@pickup)} >= 1] | $[${GROUP_COUNT(${ARG1}@qagent)} >= 1]]?s-BUSY,1)
> 
> where
> caller is set when a call is placed.
> called is set when a call is received
> pickup is set when before calling pickup in the dialplan
> qagent is set with patch to queue
> 
> Hope this is found to be useful and finds a home in trunk. 
> 
> not sure what time to put in the "wait for bridge" perhaps there is a better method ?? 
> 
> 
> This addresses bug 18830.
>     https://issues.asterisk.org/view.php?id=18830
> 
> 
> Diffs
> -----
> 
>   /trunk/apps/app_directed_pickup.c 315724 
>   /trunk/main/channel.c 315724 
> 
> Diff: https://reviewboard.asterisk.org/r/1118/diff
> 
> 
> Testing
> -------
> 
> 
> Thanks,
> 
> irroot
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-dev/attachments/20110428/e20ef7eb/attachment-0001.htm>


More information about the asterisk-dev mailing list