mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-24 04:56:14 +01:00
GDBusWorker: if a read was cancelled it means we closed the connection
This was a regression caused by my previous work on GDBusWorker thread-safety (Bug #651268). The symptom is that if you disconnect a GDBusConnection locally, the default implementation of GDBusConnection::closed terminates your process, even though it shouldn't do that for locally-closed connections; this is because GDBusWorker didn't think a cancelled read was a local close. Bug: https://bugzilla.gnome.org/show_bug.cgi?id=662100 Bug-NB: NB#287088 Signed-off-by: Simon McVittie <simon.mcvittie@collabora.co.uk> Reviewed-by: David Zeuthen <davidz@redhat.com>
This commit is contained in:
parent
6c33e1cd9d
commit
5e0492da50
@ -647,7 +647,17 @@ _g_dbus_worker_do_read_cb (GInputStream *input_stream,
|
||||
|
||||
if (bytes_read == -1)
|
||||
{
|
||||
_g_dbus_worker_emit_disconnected (worker, TRUE, error);
|
||||
/* Every async read that uses this callback uses worker->cancellable
|
||||
* as its GCancellable. worker->cancellable gets cancelled if and only
|
||||
* if the GDBusConnection tells us to close (either via
|
||||
* _g_dbus_worker_stop, which is called on last-unref, or directly),
|
||||
* so a cancelled read must mean our connection was closed locally.
|
||||
*/
|
||||
if (g_error_matches (error, G_IO_ERROR, G_IO_ERROR_CANCELLED))
|
||||
_g_dbus_worker_emit_disconnected (worker, FALSE, NULL);
|
||||
else
|
||||
_g_dbus_worker_emit_disconnected (worker, TRUE, error);
|
||||
|
||||
g_error_free (error);
|
||||
goto out;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user