Defines | |
#define | dbus_new(type, count) ((type*)dbus_malloc (sizeof (type) * (count))); |
Safe macro for using dbus_malloc(). | |
#define | dbus_new0(type, count) ((type*)dbus_malloc0 (sizeof (type) * (count))); |
Safe macro for using dbus_malloc0(). | |
Typedefs | |
typedef void(* | DBusFreeFunction )(void *memory) |
The type of a function which frees a block of memory. | |
Functions | |
void * | dbus_malloc (size_t bytes) |
Allocates the given number of bytes, as with standard malloc(). | |
void * | dbus_malloc0 (size_t bytes) |
Allocates the given number of bytes, as with standard malloc(), but all bytes are initialized to zero as with calloc(). | |
void * | dbus_realloc (void *memory, size_t bytes) |
Resizes a block of memory previously allocated by dbus_malloc() or dbus_malloc0(). | |
void | dbus_free (void *memory) |
Frees a block of memory previously allocated by dbus_malloc() or dbus_malloc0(). | |
void | dbus_free_string_array (char **str_array) |
Frees a NULL-terminated array of strings. | |
void | dbus_shutdown (void) |
The D-BUS library keeps some internal global variables, for example to cache the username of the current process. |
Functions and macros related to allocating and releasing blocks of memory.
|
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*.
Definition at line 41 of file dbus-memory.h. Referenced by _dbus_counter_new(), _dbus_register_shutdown_func(), _dbus_user_database_get_groups(), and dbus_parse_address(). |
|
|
The type of a function which frees a block of memory.
Definition at line 46 of file dbus-memory.h. |
|
Frees a block of memory previously allocated by dbus_malloc() or dbus_malloc0(). If passed NULL, does nothing.
Definition at line 612 of file dbus-memory.c. References _dbus_assert, and TRUE. Referenced by _dbus_auth_unref(), _dbus_babysitter_unref(), _dbus_connection_new_for_transport(), _dbus_counter_unref(), _dbus_data_slot_allocator_free(), _dbus_data_slot_list_free(), _dbus_directory_close(), _dbus_group_info_free(), _dbus_group_info_free_allocated(), _dbus_hash_table_new(), _dbus_hash_table_unref(), _dbus_keyring_unref(), _dbus_mem_pool_dealloc(), _dbus_mem_pool_free(), _dbus_message_loader_new(), _dbus_message_loader_unref(), _dbus_object_tree_new(), _dbus_object_tree_unref(), _dbus_pending_call_new(), _dbus_server_finalize_base(), _dbus_server_init_base(), _dbus_server_new_for_domain_socket(), _dbus_server_new_for_fd(), _dbus_string_free(), _dbus_timeout_list_free(), _dbus_timeout_unref(), _dbus_transport_finalize_base(), _dbus_transport_new_for_fd(), _dbus_transport_open(), _dbus_user_database_unref(), _dbus_user_info_free(), _dbus_user_info_free_allocated(), _dbus_watch_list_free(), _dbus_watch_unref(), dbus_address_entries_free(), dbus_connection_free_preallocated_send(), dbus_error_free(), dbus_free_string_array(), dbus_message_copy(), dbus_parse_address(), dbus_pending_call_unref(), dbus_realloc(), dbus_shutdown(), and DBusQt::Message::iterator::fillVar(). |
|
Frees a NULL-terminated array of strings. If passed NULL, does nothing.
Definition at line 650 of file dbus-memory.c. References dbus_free(). Referenced by _dbus_auth_set_mechanisms(), _dbus_auth_unref(), _dbus_decompose_path(), _dbus_dup_string_array(), _dbus_message_iter_get_args_valist(), _dbus_object_tree_dispatch_and_unlock(), _dbus_server_finalize_base(), dbus_connection_get_object_path_data(), dbus_connection_list_registered(), dbus_connection_register_fallback(), dbus_connection_register_object_path(), dbus_connection_unregister_object_path(), and dbus_server_set_auth_mechanisms(). |
|
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().
Definition at line 437 of file dbus-memory.c. References NULL. Referenced by _dbus_mem_pool_alloc(), _dbus_memdup(), _dbus_strdup(), _dbus_string_copy_data(), and _dbus_string_init_preallocated(). |
|
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().
Definition at line 488 of file dbus-memory.c. References NULL. Referenced by _dbus_mem_pool_alloc(). |
|
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.
Definition at line 539 of file dbus-memory.c. References dbus_free(), FALSE, and NULL. Referenced by _dbus_data_slot_allocator_alloc(), and _dbus_data_slot_list_set(). |
|
The D-BUS library keeps some internal global variables, for example to cache the username of the current process. This function is used to free these global variables. It is really useful only for leak-checking cleanliness and the like. WARNING: this function is NOT thread safe, it must be called while NO other threads are using D-BUS. You cannot continue using D-BUS after calling this function, as it does things like free global mutexes created by dbus_threads_init(). To use a D-BUS function after calling dbus_shutdown(), you have to start over from scratch, e.g. calling dbus_threads_init() again. Definition at line 756 of file dbus-memory.c. References ShutdownClosure::data, dbus_free(), ShutdownClosure::func, ShutdownClosure::next, and NULL. |