diff options
-rw-r--r-- | ChangeLog | 12 | ||||
-rw-r--r-- | dbus/dbus-auth.c | 2 | ||||
-rw-r--r-- | dbus/dbus-threads.c | 2 | ||||
-rw-r--r-- | glib/dbus-gmain.c | 15 |
4 files changed, 30 insertions, 1 deletions
@@ -1,5 +1,17 @@ 2003-02-16 Anders Carlsson <andersca@codefactory.se> + * dbus/dbus-auth.c: (client_try_next_mechanism): + Plug a leak. + + * dbus/dbus-threads.c: (dbus_condvar_wait_timeout): + Return TRUE if there's no thread implementation around. + + * glib/dbus-gmain.c: (free_source), + (dbus_connection_hookup_with_g_main): + Make sure to remove the GSource when the connection is finalized. + +2003-02-16 Anders Carlsson <andersca@codefactory.se> + * bus/dispatch.c: (bus_dispatch_message_handler): * dbus/dbus-errors.h: Return an error if someone tries to send a message to a service diff --git a/dbus/dbus-auth.c b/dbus/dbus-auth.c index 8125a8ed..dca83ba3 100644 --- a/dbus/dbus-auth.c +++ b/dbus/dbus-auth.c @@ -939,6 +939,8 @@ client_try_next_mechanism (DBusAuth *auth) _dbus_verbose ("Trying mechanism %s\n", auth->mech->mechanism); + _dbus_string_free (&auth_command); + return TRUE; } diff --git a/dbus/dbus-threads.c b/dbus/dbus-threads.c index 4df2e34c..0b392240 100644 --- a/dbus/dbus-threads.c +++ b/dbus/dbus-threads.c @@ -166,7 +166,7 @@ dbus_condvar_wait_timeout (DBusCondVar *cond, if (cond && mutex && thread_functions.condvar_wait) return (* thread_functions.condvar_wait_timeout) (cond, mutex, timeout_milliseconds); else - return FALSE; + return TRUE; } /** diff --git a/glib/dbus-gmain.c b/glib/dbus-gmain.c index 857ee37e..f8355a3f 100644 --- a/glib/dbus-gmain.c +++ b/glib/dbus-gmain.c @@ -36,6 +36,8 @@ struct _DBusGSource GHashTable *watches; }; +static int connection_slot = -1; + static gboolean dbus_connection_prepare (GSource *source, gint *timeout); static gboolean dbus_connection_check (GSource *source); @@ -206,6 +208,12 @@ remove_timeout (DBusTimeout *timeout, g_source_remove (timeout_tag); } +static void +free_source (GSource *source) +{ + g_source_destroy (source); +} + void dbus_connection_hookup_with_g_main (DBusConnection *connection) { @@ -228,4 +236,11 @@ dbus_connection_hookup_with_g_main (DBusConnection *connection) NULL, NULL); g_source_attach (source, NULL); + + if (connection_slot == -1 ) + connection_slot = dbus_connection_allocate_data_slot (); + + dbus_connection_set_data (connection, connection_slot, source, + (DBusFreeFunction)free_source); + } |