gsocketclient: Handle cancellation between CONNECTING and CONNECTED
authorPhilip Withnall <philip.withnall@collabora.co.uk>
Thu, 21 Aug 2014 18:00:13 +0000 (19:00 +0100)
committerPhilip Withnall <philip.withnall@collabora.co.uk>
Fri, 22 Aug 2014 18:11:26 +0000 (19:11 +0100)
If a g_socket_client_connect_async() operation is cancelled between the
CONNECTING and CONNECTED events (i.e. while in the
g_socket_connection_connect_async() call), the code in
g_socket_client_connected_callback() would previously unconditionally
loop round and try the next socket address from the address enumerator
(by calling enumerator_next_async()). This would correctly handle the
cancellation and return from the overall task — but not before emitting
a spurious RESOLVING event.

Avoid emitting the spurious RESOLVING event by explicitly handling
cancellation at the beginning of g_socket_client_connected_callback().

https://bugzilla.gnome.org/show_bug.cgi?id=735179

gio/gsocketclient.c

index 382b6b6..2cd9893 100644 (file)
@@ -1492,6 +1492,12 @@ g_socket_client_connected_callback (GObject      *source,
   GProxy *proxy;
   const gchar *protocol;
 
+  if (g_task_return_error_if_cancelled (data->task))
+    {
+      g_object_unref (data->task);
+      return;
+    }
+
   if (!g_socket_connection_connect_finish (G_SOCKET_CONNECTION (source),
                                           result, &error))
     {