summaryrefslogtreecommitdiffstats
path: root/dbus/dbus-memory.c
diff options
context:
space:
mode:
authorHavoc Pennington <hp@redhat.com>2002-11-22 22:30:02 +0000
committerHavoc Pennington <hp@redhat.com>2002-11-22 22:30:02 +0000
commit8164139fa6259257817898b3d389d96bd60f8c13 (patch)
tree580a092f9afbe3c1316b9640681a3e82de9a9d1d /dbus/dbus-memory.c
parent1a4cb6b95ffc3acdef34b6f014a83c02be963fae (diff)
2002-11-22 Havoc Pennington <hp@redhat.com>
* dbus/dbus.h: fixups for doc warnings * Doxyfile.in (FILE_PATTERNS): we need to scan .h to pick up macros (QUIET): make it quiet so we can see warnings * dbus/dbus-memory.c: teach D-BUS to allocate and free memory
Diffstat (limited to 'dbus/dbus-memory.c')
-rw-r--r--dbus/dbus-memory.c139
1 files changed, 139 insertions, 0 deletions
diff --git a/dbus/dbus-memory.c b/dbus/dbus-memory.c
new file mode 100644
index 00000000..018c45d3
--- /dev/null
+++ b/dbus/dbus-memory.c
@@ -0,0 +1,139 @@
+/* -*- mode: C; c-file-style: "gnu" -*- */
+/* dbus-memory.c D-BUS memory handling
+ *
+ * Copyright (C) 2002 Red Hat Inc.
+ *
+ * Licensed under the Academic Free License version 1.2
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
+#include "dbus-memory.h"
+#include <stdlib.h>
+
+/**
+ * @defgroup Memory Memory Allocation
+ * @ingroup DBus
+ * @brief dbus_malloc(), dbus_free(), etc.
+ *
+ * Functions and macros related to allocating and releasing
+ * blocks of memory.
+ *
+ * @{
+ */
+
+/**
+ * @def dbus_new
+ *
+ * Safe macro for using dbus_malloc(). Accepts the type
+ * to allocate and the number of type instances to
+ * allocate as arguments, and returns a memory block
+ * cast to the desired type, instead of as a void*.
+ *
+ * @param type type name to allocate
+ * @param count number of instances in the allocated array
+ * @returns the new memory block or NULL on failure
+ */
+
+/**
+ * @def dbus_new0
+ *
+ * Safe macro for using dbus_malloc0(). Accepts the type
+ * to allocate and the number of type instances to
+ * allocate as arguments, and returns a memory block
+ * cast to the desired type, instead of as a void*.
+ * The allocated array is initialized to all-bits-zero.
+ *
+ * @param type type name to allocate
+ * @param count number of instances in the allocated array
+ * @returns the new memory block or NULL on failure
+ */
+
+/**
+ * Allocates the given number of bytes, as with standard
+ * malloc(). Guaranteed to return NULL if bytes is zero
+ * on all platforms. Returns NULL if the allocation fails.
+ * The memory must be released with dbus_free().
+ *
+ * @param bytes number of bytes to allocate
+ * @return allocated memory, or NULL if the allocation fails.
+ */
+void*
+dbus_malloc (size_t bytes)
+{
+ if (bytes == 0) /* some system mallocs handle this, some don't */
+ return NULL;
+ else
+ return malloc (bytes);
+}
+
+/**
+ * Allocates the given number of bytes, as with standard malloc(), but
+ * all bytes are initialized to zero as with calloc(). Guaranteed to
+ * return NULL if bytes is zero on all platforms. Returns NULL if the
+ * allocation fails. The memory must be released with dbus_free().
+ *
+ * @param bytes number of bytes to allocate
+ * @return allocated memory, or NULL if the allocation fails.
+ */
+void*
+dbus_malloc0 (size_t bytes)
+{
+ if (bytes == 0)
+ return NULL;
+ else
+ return calloc (bytes, 1);
+}
+
+/**
+ * Resizes a block of memory previously allocated by dbus_malloc() or
+ * dbus_malloc0(). Guaranteed to free the memory and return NULL if bytes
+ * is zero on all platforms. Returns NULL if the resize fails.
+ * If the resize fails, the memory is not freed.
+ *
+ * @param memory block to be resized
+ * @param bytes new size of the memory block
+ * @return allocated memory, or NULL if the resize fails.
+ */
+void*
+dbus_realloc (void *memory,
+ size_t bytes)
+{
+ if (bytes == 0) /* guarantee this is safe */
+ {
+ dbus_free (memory);
+ return NULL;
+ }
+ else
+ {
+ return realloc (memory, bytes);
+ }
+}
+
+/**
+ * Frees a block of memory previously allocated by dbus_malloc() or
+ * dbus_malloc0().
+ *
+ * @param memory block to be freed
+ */
+void
+dbus_free (void *memory)
+{
+ if (memory) /* we guarantee it's safe to free (NULL) */
+ free (memory);
+}
+
+/** @} */