summaryrefslogtreecommitdiff
path: root/include/asterisk
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2004-12-29 07:50:15 +0000
committerMark Spencer <markster@digium.com>2004-12-29 07:50:15 +0000
commit9aace6da4938f529f883a9c45cfa71a3d9ecac93 (patch)
treefe102087d96c9b25bf2a9346ec2e1779682234dd /include/asterisk
parentf19f4411e106e31e6ce56fda9399b081e555ed9d (diff)
Merge remainder of kpfleming's astobj patch (bug #3183)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@4582 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'include/asterisk')
-rwxr-xr-xinclude/asterisk/astobj.h5
1 files changed, 3 insertions, 2 deletions
diff --git a/include/asterisk/astobj.h b/include/asterisk/astobj.h
index 162654024..a70cf70aa 100755
--- a/include/asterisk/astobj.h
+++ b/include/asterisk/astobj.h
@@ -179,6 +179,7 @@ extern "C" {
while((iterator = (container)->head)) { \
(container)->head = (iterator)->next[0]; \
ASTOBJ_DESTROY(iterator,destructor); \
+ ASTOBJ_UNREF(iterator,destructor); \
} \
ASTOBJ_CONTAINER_UNLOCK(container); \
} while(0)
@@ -190,7 +191,7 @@ extern "C" {
ASTOBJ_CONTAINER_TRAVERSE(container, do { \
ASTOBJ_RDLOCK(iterator); \
if (!(comparefunc(iterator->field, (data)))) { \
- found = ASTOBJ_REF(iterator); \
+ found = iterator; \
ASTOBJ_CONTAINER_WRLOCK(container); \
if (prev) \
prev->next[0] = next; \
@@ -232,7 +233,7 @@ extern "C" {
do { \
ASTOBJ_CONTAINER_WRLOCK(container); \
(newobj)->next[0] = (container)->head; \
- (container)->head = (newobj); \
+ (container)->head = ASTOBJ_REF(newobj); \
ASTOBJ_CONTAINER_UNLOCK(container); \
} while(0)