summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2004-01-29 16:14:25 +0000
committerMark Spencer <markster@digium.com>2004-01-29 16:14:25 +0000
commitccf510188f6baee3fb90e2a2192f24ca8c994d9d (patch)
tree9cc3b8252530e26ad4d13a00dafc49f2f201f529 /include
parenteb97ef73fab0b83eb3512dccd27e5a8566f70256 (diff)
Fix linked lists tail (bug #951)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@2090 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'include')
-rwxr-xr-xinclude/asterisk/linkedlists.h10
1 files changed, 7 insertions, 3 deletions
diff --git a/include/asterisk/linkedlists.h b/include/asterisk/linkedlists.h
index 30e09a015..01067d5f0 100755
--- a/include/asterisk/linkedlists.h
+++ b/include/asterisk/linkedlists.h
@@ -55,10 +55,14 @@ struct { \
#define AST_LIST_INSERT_TAIL(head, elm, type, field) do { \
struct type *curelm = (head)->first; \
- while ( curelm->field.next!=NULL ) { \
- curelm=curelm->field.next; \
+ if(!curelm) { \
+ AST_LIST_INSERT_HEAD(head, elm, field); \
+ } else { \
+ while ( curelm->field.next!=NULL ) { \
+ curelm=curelm->field.next; \
+ } \
+ AST_LIST_INSERT_AFTER(curelm,elm,field); \
} \
- AST_LIST_INSERT_AFTER(curelm,elm,field); \
} while (0)