diff options
author | Marc-André Lureau <marcandre.lureau@gmail.com> | 2015-02-18 17:51:01 +0100 |
---|---|---|
committer | Marc-André Lureau <marcandre.lureau@gmail.com> | 2015-02-21 00:17:27 +0100 |
commit | 1d03dc888f0d73416a0cbc1ade3242f87fd21780 (patch) | |
tree | 0b624c49cf984f76ed52d73ca327f5bb8a07d28a | |
parent | 01b4164a0a9fea88c12d93baa2dd04cb6e7bbf83 (diff) | |
download | libsoup-1d03dc888f0d73416a0cbc1ade3242f87fd21780.tar.gz |
soup-server: add non-GSocket fallbacks for client context
If the SoupSocket doesn't have a GSocket, it may still have addresses
filled.
https://bugzilla.gnome.org/show_bug.cgi?id=744186
-rw-r--r-- | libsoup/soup-server.c | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/libsoup/soup-server.c b/libsoup/soup-server.c index b88e485f..69cd48fb 100644 --- a/libsoup/soup-server.c +++ b/libsoup/soup-server.c @@ -2146,10 +2146,18 @@ soup_client_context_get_address (SoupClientContext *client) GSocketAddress * soup_client_context_get_remote_address (SoupClientContext *client) { + GSocket *sock; + g_return_val_if_fail (client != NULL, NULL); - if (!client->remote_addr) - client->remote_addr = g_socket_get_remote_address (soup_client_context_get_gsocket (client), NULL); + if (client->remote_addr) + return client->remote_addr; + + sock = soup_client_context_get_gsocket (client); + client->remote_addr = sock ? + g_socket_get_remote_address (sock, NULL) : + soup_address_get_gsockaddr (soup_socket_get_remote_address (client->sock)); + return client->remote_addr; } @@ -2169,10 +2177,18 @@ soup_client_context_get_remote_address (SoupClientContext *client) GSocketAddress * soup_client_context_get_local_address (SoupClientContext *client) { + GSocket *sock; + g_return_val_if_fail (client != NULL, NULL); - if (!client->local_addr) - client->local_addr = g_socket_get_local_address (soup_client_context_get_gsocket (client), NULL); + if (client->local_addr) + return client->local_addr; + + sock = soup_client_context_get_gsocket (client); + client->local_addr = sock ? + g_socket_get_local_address (sock, NULL) : + soup_address_get_gsockaddr (soup_socket_get_local_address (client->sock)); + return client->local_addr; } |