+2003-03-16 Havoc Pennington <hp@pobox.com>
+
+ * dbus/dbus-bus.c (ensure_bus_data): fix double-unref of the data slot
+
2003-03-17 Anders Carlsson <andersca@codefactory.se>
* bus/activation.c (bus_activation_activate_service): Append
check1_try_iterations (context, "create_and_hello",
check_hello_connection);
-
+
dbus_connection_disconnect (foo);
if (bus_connection_dispatch_one_message (foo))
_dbus_assert_not_reached ("extra message in queue");
dbus_mutex_lock (slot_lock);
if (bus_data_slot < 0)
- bus_data_slot = dbus_connection_allocate_data_slot ();
-
- if (bus_data_slot < 0)
{
- dbus_mutex_unlock (slot_lock);
- return FALSE;
+ bus_data_slot = dbus_connection_allocate_data_slot ();
+
+ if (bus_data_slot < 0)
+ {
+ dbus_mutex_unlock (slot_lock);
+ return FALSE;
+ }
+
+ _dbus_assert (bus_data_slot_refcount == 0);
}
bus_data_slot_refcount += 1;
{
dbus_mutex_lock (slot_lock);
- _dbus_assert (bus_data_slot >= 0);
_dbus_assert (bus_data_slot_refcount > 0);
+ _dbus_assert (bus_data_slot >= 0);
bus_data_slot_refcount -= 1;
if (!dbus_connection_set_data (connection, bus_data_slot, bd,
bus_data_free))
{
- bus_data_free (bd);
+ dbus_free (bd);
data_slot_unref ();
return NULL;
}
DBusHashIter iter;
DBusList *link;
+ _dbus_assert (connection->refcount == 0);
+
/* You have to disconnect the connection before unref:ing it. Otherwise
* you won't get the disconnected message.
*/