summaryrefslogtreecommitdiffstats
path: root/dbus/dbus-transport-debug.c
diff options
context:
space:
mode:
authorHavoc Pennington <hp@redhat.com>2003-03-17 01:54:37 +0000
committerHavoc Pennington <hp@redhat.com>2003-03-17 01:54:37 +0000
commitb4a1100f4f81534e2aac0141afda750f318223d4 (patch)
tree9573e47181fc32c40f4784df0d22b2c6ee4143c4 /dbus/dbus-transport-debug.c
parent3caaa342e8db2cba690bb9e1a228ef3862e203d8 (diff)
2003-03-16 Havoc Pennington <hp@pobox.com>
* dbus/dbus-watch.c (_dbus_watch_new): handle failure to malloc the watch * dbus/dbus-server-debug-pipe.c (_dbus_transport_debug_pipe_new): add some missing dbus_set_result * bus/dispatch.c (bus_dispatch_add_connection): handle failure to alloc the DBusMessageHandler * dbus/dbus-transport.c (_dbus_transport_disconnect): don't ref the transport here, since we call this from the finalizer; it resulted in a double-finalize. * dbus/dbus-transport.c (_dbus_transport_disconnect): fix a bug where we tried to use transport->connection that was NULL, happened when transport was disconnected early on due to OOM * bus/*.c: adapt to handle OOM for watches/timeouts * dbus/dbus-transport-unix.c: port to handle OOM during watch handling * dbus/dbus-auth.c (_dbus_auth_get_unused_bytes): return a reference to unused bytes instead of a copy * dbus/dbus-server.c (dbus_server_handle_watch): return FALSE for out of memory * dbus/dbus-connection.c (dbus_connection_handle_watch): return FALSE on OOM * dbus/dbus-timeout.c (dbus_timeout_handle): return FALSE for out of memory
Diffstat (limited to 'dbus/dbus-transport-debug.c')
-rw-r--r--dbus/dbus-transport-debug.c36
1 files changed, 23 insertions, 13 deletions
diff --git a/dbus/dbus-transport-debug.c b/dbus/dbus-transport-debug.c
index a7db3a6e..d477339a 100644
--- a/dbus/dbus-transport-debug.c
+++ b/dbus/dbus-transport-debug.c
@@ -48,11 +48,13 @@
#define DEFAULT_INTERVAL 1
/**
- * Hack due to lack of OOM handling in a couple places
+ * Hack due to lack of OOM handling in a couple places.
+ * Need to alloc timeout permanently and enabled/disable so
+ * that check_timeout won't fail in messages_pending
*/
#define WAIT_FOR_MEMORY() _dbus_sleep_milliseconds (250)
-static void check_timeout (DBusTransport *transport);
+static dbus_bool_t check_timeout (DBusTransport *transport);
/**
* Opaque object representing a debug transport.
@@ -123,18 +125,21 @@ move_messages (DBusTransport *transport)
return TRUE;
}
-static void
+static dbus_bool_t
timeout_handler (void *data)
{
DBusTransport *transport = data;
- while (!move_messages (transport))
- WAIT_FOR_MEMORY ();
+ if (!move_messages (transport))
+ return FALSE;
+
+ if (!check_timeout (transport))
+ return FALSE;
- check_timeout (transport);
+ return TRUE;
}
-static void
+static dbus_bool_t
check_timeout (DBusTransport *transport)
{
DBusTransportDebug *debug_transport = (DBusTransportDebug*) transport;
@@ -150,9 +155,9 @@ check_timeout (DBusTransport *transport)
/* FIXME this can be fixed now, by enabling/disabling
* the timeout instead of adding it here
*/
- while (!_dbus_connection_add_timeout (transport->connection,
- debug_transport->timeout))
- WAIT_FOR_MEMORY ();
+ if (!_dbus_connection_add_timeout (transport->connection,
+ debug_transport->timeout))
+ return FALSE;
debug_transport->timeout_added = TRUE;
}
}
@@ -165,6 +170,8 @@ check_timeout (DBusTransport *transport)
debug_transport->timeout_added = FALSE;
}
}
+
+ return TRUE;
}
static void
@@ -189,11 +196,12 @@ debug_finalize (DBusTransport *transport)
dbus_free (transport);
}
-static void
+static dbus_bool_t
debug_handle_watch (DBusTransport *transport,
DBusWatch *watch,
unsigned int flags)
{
+ return TRUE;
}
static void
@@ -204,7 +212,8 @@ debug_disconnect (DBusTransport *transport)
static dbus_bool_t
debug_connection_set (DBusTransport *transport)
{
- check_timeout (transport);
+ if (!check_timeout (transport))
+ return FALSE;
return TRUE;
}
@@ -212,7 +221,8 @@ static void
debug_messages_pending (DBusTransport *transport,
int messages_pending)
{
- check_timeout (transport);
+ while (!check_timeout (transport))
+ WAIT_FOR_MEMORY ();
}
static void