From a284b8071436e02064074e08d56dfcc6702c5250 Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Sat, 25 Jan 2003 00:11:41 +0000 Subject: 2003-01-25 Anders Carlsson * dbus/dbus-list.c: (alloc_link), (free_link): Use a memory pool for the links. --- dbus/dbus-list.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) (limited to 'dbus/dbus-list.c') diff --git a/dbus/dbus-list.c b/dbus/dbus-list.c index c36246cb..42fc79bf 100644 --- a/dbus/dbus-list.c +++ b/dbus/dbus-list.c @@ -23,6 +23,7 @@ #include "dbus-internals.h" #include "dbus-list.h" +#include "dbus-mempool.h" /** * @defgroup DBusList Linked list @@ -32,6 +33,8 @@ * Types and functions related to DBusList. */ +static DBusMemPool *list_pool; + /** * @defgroup DBusListInternals Linked list implementation details * @ingroup DBusInternals @@ -39,8 +42,6 @@ * * The guts of DBusList. * - * @todo should use a memory pool for the list nodes, to avoid - * a memory allocation for every link. * @{ */ @@ -49,7 +50,10 @@ alloc_link (void *data) { DBusList *link; - link = dbus_new0 (DBusList, 1); + if (!list_pool) + list_pool = _dbus_mem_pool_new (sizeof (DBusList), TRUE); + + link = _dbus_mem_pool_alloc (list_pool); link->data = data; return link; @@ -58,7 +62,7 @@ alloc_link (void *data) static void free_link (DBusList *link) { - dbus_free (link); + _dbus_mem_pool_dealloc (list_pool, link); } static void -- cgit