https://origsvn.digium.com/svn/asterisk/trunk
........
r182553 | russell | 2009-03-17 10:22:12 -0500 (Tue, 17 Mar 2009) | 5 lines
Tweak the handling of the frame list inside of ast_answer().
This does not change any behavior, but moves the frames from the local frame
list back to the channel read queue using an O(n) algorithm instead of O(n^2).
........
git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.1@182570
65c4cc65-6c06-0410-ace0-
fbb531ad65f3
ast_frfree(cur);
}
- AST_LIST_INSERT_TAIL(&frames, new, frame_list);
+ AST_LIST_INSERT_HEAD(&frames, new, frame_list);
/* if a specific delay period was requested, continue
* until that delay has passed. don't stop just because
if (res == 0) {
ast_channel_lock(chan);
- while ((cur = AST_LIST_LAST(&frames))) {
- AST_LIST_REMOVE(&frames, cur, frame_list);
+ while ((cur = AST_LIST_REMOVE_HEAD(&frames, frame_list))) {
ast_queue_frame_head(chan, cur);
ast_frfree(cur);
}